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