diff options
author | Lennart Poettering <lennart@poettering.net> | 2005-08-13 21:25:09 +0000 |
---|---|---|
committer | Lennart Poettering <lennart@poettering.net> | 2005-08-13 21:25:09 +0000 |
commit | 4f0a5e7572a4257894b4bfede42c26d65152609e (patch) | |
tree | 21e3d5ee20716739590e5931859a4c2052161395 /avahi-common/watch-test.c | |
parent | d6d7d3769441b73ffb5b7af34fef823b41e66312 (diff) |
* strip glib from avahi-core
* implement glib memory allocator
* add new documentation file MALLOC
* initialize pseudo-RNG from /dev/urandom in avahi-daemon
* remove some gcc 4.0 warnings
* beef up watch system with real timeouts
* move GCC __attribute__ macros into its own header avahi-common/gccmacro.h
* make use of GCC's sentinel attribute where it make sense
* add malloc() implementations that abort on OOM and enable them by default
git-svn-id: file:///home/lennart/svn/public/avahi/trunk@308 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe
Diffstat (limited to 'avahi-common/watch-test.c')
-rw-r--r-- | avahi-common/watch-test.c | 41 |
1 files changed, 23 insertions, 18 deletions
diff --git a/avahi-common/watch-test.c b/avahi-common/watch-test.c index f87a303..af46805 100644 --- a/avahi-common/watch-test.c +++ b/avahi-common/watch-test.c @@ -34,6 +34,7 @@ #include "timeval.h" static AvahiPoll *api = NULL; +static AvahiSimplePoll *simple_poll = NULL; static void callback(AvahiWatch *w, int fd, AvahiWatchEvent event, void *userdata) { @@ -51,31 +52,35 @@ static void callback(AvahiWatch *w, int fd, AvahiWatchEvent event, void *userdat } } +static void wakeup(AvahiPoll *_api, void *userdata) { + static int i = 0; + struct timeval tv; + + printf("Wakeup #%i\n", i++); + + if (i > 10) + avahi_simple_poll_quit(simple_poll); + else { + avahi_elapse_time(&tv, 1000, 0); + api->set_wakeup(api, &tv, wakeup, NULL); + } +} + int main(int argc, char *argv[]) { - int i = 0; - AvahiSimplePoll *s; + struct timeval tv; - s = avahi_simple_poll_new(); - assert(s); - - api = avahi_simple_poll_get(s); + simple_poll = avahi_simple_poll_new(); + api = avahi_simple_poll_get(simple_poll); api->watch_new(api, 0, AVAHI_WATCH_IN, callback, NULL); - for (;;) { - struct timeval tv; - printf("Iteration %i\n", i++); - - if (i > 100) - avahi_simple_poll_quit(s); + avahi_elapse_time(&tv, 1000, 0); + api->set_wakeup(api, &tv, wakeup, NULL); - avahi_elapse_time(&tv, 1000, 0); - - api->set_wakeup_time(api, &tv); - - if (avahi_simple_poll_iterate(s, 1) != 0) + /* Our main loop */ + for (;;) + if (avahi_simple_poll_iterate(simple_poll, -1) != 0) break; - } return 0; } |