X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-core%2Ftimeeventq-test.c;h=d7b2e39c97f894e353f0810caafb7a9f92f52f23;hb=9c0f9c65093cfa53d45f9b68782321eb8063a032;hp=213488e1e13ba5059956ad0e3f239f21c950ada5;hpb=774b0629a3536eda0b560e092964cf94d6b742aa;p=catta diff --git a/avahi-core/timeeventq-test.c b/avahi-core/timeeventq-test.c index 213488e..d7b2e39 100644 --- a/avahi-core/timeeventq-test.c +++ b/avahi-core/timeeventq-test.c @@ -1,18 +1,16 @@ -/* $Id$ */ - /*** This file is part of avahi. - + avahi is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. - + avahi is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. - + You should have received a copy of the GNU Lesser General Public License along with avahi; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 @@ -23,37 +21,47 @@ #include #endif -#include +#include +#include + +#include +#include -#include "util.h" #include "timeeventq.h" +#include "log.h" + +#define POINTER_TO_INT(p) ((int) (long) (p)) +#define INT_TO_POINTER(i) ((void*) (long) (i)) static AvahiTimeEventQueue *q = NULL; -void callback(AvahiTimeEvent*e, gpointer userdata) { - GTimeVal tv = {0, 0}; - g_assert(e); - g_message("callback(%i)", GPOINTER_TO_INT(userdata)); +static void callback(AvahiTimeEvent*e, void* userdata) { + struct timeval tv = {0, 0}; + assert(e); + avahi_log_info("callback(%i)", POINTER_TO_INT(userdata)); avahi_elapse_time(&tv, 1000, 100); - avahi_time_event_queue_update(q, e, &tv); + avahi_time_event_update(e, &tv); } -int main(int argc, char *argv[]) { - GMainLoop *loop = NULL; - GTimeVal tv; - - q = avahi_time_event_queue_new(NULL, 0); +int main(AVAHI_GCC_UNUSED int argc, AVAHI_GCC_UNUSED char *argv[]) { + struct timeval tv; + AvahiSimplePoll *s; + + s = avahi_simple_poll_new(); + + q = avahi_time_event_queue_new(avahi_simple_poll_get(s)); + + avahi_time_event_new(q, avahi_elapse_time(&tv, 5000, 100), callback, INT_TO_POINTER(1)); + avahi_time_event_new(q, avahi_elapse_time(&tv, 5000, 100), callback, INT_TO_POINTER(2)); - avahi_time_event_queue_add(q, avahi_elapse_time(&tv, 5000, 100), callback, GINT_TO_POINTER(1)); - avahi_time_event_queue_add(q, avahi_elapse_time(&tv, 5000, 100), callback, GINT_TO_POINTER(2)); + avahi_log_info("starting"); - g_message("starting"); - - loop = g_main_loop_new(NULL, FALSE); - g_main_loop_run(loop); - g_main_loop_unref(loop); + for (;;) + if (avahi_simple_poll_iterate(s, -1) != 0) + break; avahi_time_event_queue_free(q); + avahi_simple_poll_free(s); return 0; }