/* * Compile with: * cc -I/usr/local/include -o time-test time-test.c -L/usr/local/lib -levent */ #include #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #ifndef WIN32 #include #include #endif #include #ifdef HAVE_SYS_TIME_H #include #endif #include #include #include #include #include #include #include int lasttime; void timeout_cb(int fd, short event, void *arg) { struct timeval tv; struct event *timeout = arg; int newtime = time(NULL); printf("%s: called at %d: %d\n", __func__, newtime, newtime - lasttime); lasttime = newtime; evutil_timerclear(&tv); tv.tv_sec = 2; event_add(timeout, &tv); } int main (int argc, char **argv) { struct event timeout; struct timeval tv; /* Initalize the event library */ event_init(); /* Initalize one event */ evtimer_set(&timeout, timeout_cb, &timeout); evutil_timerclear(&tv); tv.tv_sec = 2; event_add(&timeout, &tv); lasttime = time(NULL); event_dispatch(); return (0); }