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