diff options
Diffstat (limited to 'trunk/avahi-core/timeeventq-test.c')
-rw-r--r-- | trunk/avahi-core/timeeventq-test.c | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/trunk/avahi-core/timeeventq-test.c b/trunk/avahi-core/timeeventq-test.c new file mode 100644 index 0000000..c66a55a --- /dev/null +++ b/trunk/avahi-core/timeeventq-test.c @@ -0,0 +1,69 @@ +/* $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 + USA. +***/ + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include <assert.h> +#include <stdlib.h> + +#include <avahi-common/timeval.h> +#include <avahi-common/simple-watch.h> + +#include "timeeventq.h" +#include "log.h" + +#define POINTER_TO_INT(p) ((int) (p)) +#define INT_TO_POINTER(i) ((void*) (i)) + +static AvahiTimeEventQueue *q = NULL; + +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_update(e, &tv); +} + +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_log_info("starting"); + + for (;;) + if (avahi_simple_poll_iterate(s, -1) != 0) + break; + + avahi_time_event_queue_free(q); + avahi_simple_poll_free(s); + + return 0; +} |