| /* | |
| * 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); | |
| } | |