/* * Compile with: * cc -I/usr/local/include -o time-test time-test.c -L/usr/local/lib -levent */ #include <sys/types.h> #ifdef HAVE_CONFIG_H #include "config.h" #endif #include <sys/stat.h> #ifndef WIN32 #include <sys/queue.h> #include <unistd.h> #endif #include <time.h> #ifdef HAVE_SYS_TIME_H #include <sys/time.h> #endif #include <fcntl.h> #include <stdlib.h> #include <stdio.h> #include <string.h> #include <errno.h> #include <event.h> #include <evutil.h> int lasttime; static 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); }