X-Git-Url: https://www.tinc-vpn.org/git/browse?p=tinc;a=blobdiff_plain;f=src%2Fevent.c;h=8a63e12d39fa4d598f8daef9b51016e3d87a9466;hp=295e28f19e9394976054452230e932a169c47ce9;hb=e9576632dc4b780b867044269d06cc50f76d8c05;hpb=627f7c22b447bd464b536cd016278545674df93d diff --git a/src/event.c b/src/event.c index 295e28f1..8a63e12d 100644 --- a/src/event.c +++ b/src/event.c @@ -1,7 +1,7 @@ /* event.c -- event queue - Copyright (C) 2002 Guus Sliepen , - 2002 Ivo Timmermans + Copyright (C) 2002-2007 Guus Sliepen , + 2002-2005 Ivo Timmermans This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,94 +17,111 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id: event.c,v 1.1.4.3 2002/06/21 10:11:12 guus Exp $ + $Id$ */ -#include "config.h" - -#include -#include -#include -#include -#include -#include +#include "system.h" +#include "avl_tree.h" #include "event.h" - -#include "system.h" +#include "utils.h" +#include "xalloc.h" avl_tree_t *event_tree; extern time_t now; int id; -int event_compare(event_t *a, event_t *b) +static int event_compare(const event_t *a, const event_t *b) { - if(a->time > b->time) - return 1; - if(a->time < b->time) - return -1; - return a->id - b->id; + if(a->time > b->time) + return 1; + + if(a->time < b->time) + return -1; + + return a->id - b->id; } void init_events(void) { -cp - event_tree = avl_alloc_tree((avl_compare_t)event_compare, NULL); -cp + cp(); + + event_tree = avl_alloc_tree((avl_compare_t) event_compare, NULL); } void exit_events(void) { -cp - avl_delete_tree(event_tree); -cp + cp(); + + avl_delete_tree(event_tree); +} + +void flush_events(void) +{ + avl_tree_t *to_flush; + event_t *event; + + /* + * Events can be inserted from event handlers, so only flush events + * already in the priority queue. + */ + + cp(); + + to_flush = event_tree; + init_events(); + while (to_flush->head) { + event = to_flush->head->data; + event->handler(event->data); + avl_delete(to_flush, event); + } + avl_delete_tree(to_flush); } event_t *new_event(void) { - event_t *event; -cp - event = (event_t *)xmalloc_and_zero(sizeof(*event)); -cp - return event; + cp(); + + return xmalloc_and_zero(sizeof(event_t)); } void free_event(event_t *event) { -cp - free(event); -cp + cp(); + + free(event); } void event_add(event_t *event) { -cp - event->id = ++id; - avl_insert(event_tree, event); -cp + cp(); + + event->id = ++id; + avl_insert(event_tree, event); } void event_del(event_t *event) { -cp - avl_delete(event_tree, event); -cp + cp(); + + avl_delete(event_tree, event); } event_t *get_expired_event(void) { - event_t *event; -cp - if(event_tree->head) - { - event = (event_t *)event_tree->head->data; - if(event->time < now) - { - avl_delete(event_tree, event); - return event; - } - } -cp - return NULL; + event_t *event; + + cp(); + + if(event_tree->head) { + event = event_tree->head->data; + + if(event->time < now) { + event_del(event); + return event; + } + } + + return NULL; }