]> git.meshlink.io Git - catta/blob - avahi-core/timeeventq-test.c
build-sys: make things more quiet
[catta] / avahi-core / timeeventq-test.c
1 /* $Id$ */
2
3 /***
4   This file is part of avahi.
5
6   avahi is free software; you can redistribute it and/or modify it
7   under the terms of the GNU Lesser General Public License as
8   published by the Free Software Foundation; either version 2.1 of the
9   License, or (at your option) any later version.
10
11   avahi is distributed in the hope that it will be useful, but WITHOUT
12   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13   or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
14   Public License for more details.
15
16   You should have received a copy of the GNU Lesser General Public
17   License along with avahi; if not, write to the Free Software
18   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19   USA.
20 ***/
21
22 #ifdef HAVE_CONFIG_H
23 #include <config.h>
24 #endif
25
26 #include <assert.h>
27 #include <stdlib.h>
28
29 #include <avahi-common/timeval.h>
30 #include <avahi-common/simple-watch.h>
31
32 #include "timeeventq.h"
33 #include "log.h"
34
35 #define POINTER_TO_INT(p) ((int) (long) (p))
36 #define INT_TO_POINTER(i) ((void*) (long) (i))
37
38 static AvahiTimeEventQueue *q = NULL;
39
40 static void callback(AvahiTimeEvent*e, void* userdata) {
41     struct timeval tv = {0, 0};
42     assert(e);
43     avahi_log_info("callback(%i)", POINTER_TO_INT(userdata));
44     avahi_elapse_time(&tv, 1000, 100);
45     avahi_time_event_update(e, &tv);
46 }
47
48 int main(AVAHI_GCC_UNUSED int argc, AVAHI_GCC_UNUSED char *argv[]) {
49     struct timeval tv;
50     AvahiSimplePoll *s;
51
52     s = avahi_simple_poll_new();
53
54     q = avahi_time_event_queue_new(avahi_simple_poll_get(s));
55
56     avahi_time_event_new(q, avahi_elapse_time(&tv, 5000, 100), callback, INT_TO_POINTER(1));
57     avahi_time_event_new(q, avahi_elapse_time(&tv, 5000, 100), callback, INT_TO_POINTER(2));
58
59     avahi_log_info("starting");
60
61     for (;;)
62         if (avahi_simple_poll_iterate(s, -1) != 0)
63             break;
64
65     avahi_time_event_queue_free(q);
66     avahi_simple_poll_free(s);
67
68     return 0;
69 }