From 774b0629a3536eda0b560e092964cf94d6b742aa Mon Sep 17 00:00:00 2001 From: Lennart Poettering Date: Sat, 16 Jul 2005 20:14:34 +0000 Subject: * hide some more files * make sure not to run a time event twice in the same main loop iteration * add new test timeeventq-test git-svn-id: file:///home/lennart/svn/public/avahi/trunk@167 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe --- avahi-core/timeeventq-test.c | 59 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 avahi-core/timeeventq-test.c (limited to 'avahi-core/timeeventq-test.c') diff --git a/avahi-core/timeeventq-test.c b/avahi-core/timeeventq-test.c new file mode 100644 index 0000000..213488e --- /dev/null +++ b/avahi-core/timeeventq-test.c @@ -0,0 +1,59 @@ +/* $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 +#endif + +#include + +#include "util.h" +#include "timeeventq.h" + +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)); + avahi_elapse_time(&tv, 1000, 100); + avahi_time_event_queue_update(q, e, &tv); +} + +int main(int argc, char *argv[]) { + GMainLoop *loop = NULL; + GTimeVal tv; + + q = avahi_time_event_queue_new(NULL, 0); + + 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)); + + g_message("starting"); + + loop = g_main_loop_new(NULL, FALSE); + g_main_loop_run(loop); + g_main_loop_unref(loop); + + avahi_time_event_queue_free(q); + + return 0; +} -- cgit