1*6777b538SAndroid Build Coastguard Worker /*
2*6777b538SAndroid Build Coastguard Worker * Compile with:
3*6777b538SAndroid Build Coastguard Worker * cc -I/usr/local/include -o time-test time-test.c -L/usr/local/lib -levent
4*6777b538SAndroid Build Coastguard Worker */
5*6777b538SAndroid Build Coastguard Worker
6*6777b538SAndroid Build Coastguard Worker #include <sys/types.h>
7*6777b538SAndroid Build Coastguard Worker
8*6777b538SAndroid Build Coastguard Worker #ifdef HAVE_CONFIG_H
9*6777b538SAndroid Build Coastguard Worker #include "config.h"
10*6777b538SAndroid Build Coastguard Worker #endif
11*6777b538SAndroid Build Coastguard Worker
12*6777b538SAndroid Build Coastguard Worker #include <sys/stat.h>
13*6777b538SAndroid Build Coastguard Worker #ifndef WIN32
14*6777b538SAndroid Build Coastguard Worker #include <sys/queue.h>
15*6777b538SAndroid Build Coastguard Worker #include <unistd.h>
16*6777b538SAndroid Build Coastguard Worker #endif
17*6777b538SAndroid Build Coastguard Worker #include <time.h>
18*6777b538SAndroid Build Coastguard Worker #ifdef HAVE_SYS_TIME_H
19*6777b538SAndroid Build Coastguard Worker #include <sys/time.h>
20*6777b538SAndroid Build Coastguard Worker #endif
21*6777b538SAndroid Build Coastguard Worker #include <fcntl.h>
22*6777b538SAndroid Build Coastguard Worker #include <stdlib.h>
23*6777b538SAndroid Build Coastguard Worker #include <stdio.h>
24*6777b538SAndroid Build Coastguard Worker #include <string.h>
25*6777b538SAndroid Build Coastguard Worker #include <errno.h>
26*6777b538SAndroid Build Coastguard Worker
27*6777b538SAndroid Build Coastguard Worker #include <event.h>
28*6777b538SAndroid Build Coastguard Worker #include <evutil.h>
29*6777b538SAndroid Build Coastguard Worker
30*6777b538SAndroid Build Coastguard Worker int lasttime;
31*6777b538SAndroid Build Coastguard Worker
32*6777b538SAndroid Build Coastguard Worker static void
timeout_cb(int fd,short event,void * arg)33*6777b538SAndroid Build Coastguard Worker timeout_cb(int fd, short event, void *arg)
34*6777b538SAndroid Build Coastguard Worker {
35*6777b538SAndroid Build Coastguard Worker struct timeval tv;
36*6777b538SAndroid Build Coastguard Worker struct event *timeout = arg;
37*6777b538SAndroid Build Coastguard Worker int newtime = time(NULL);
38*6777b538SAndroid Build Coastguard Worker
39*6777b538SAndroid Build Coastguard Worker printf("%s: called at %d: %d\n", __func__, newtime,
40*6777b538SAndroid Build Coastguard Worker newtime - lasttime);
41*6777b538SAndroid Build Coastguard Worker lasttime = newtime;
42*6777b538SAndroid Build Coastguard Worker
43*6777b538SAndroid Build Coastguard Worker evutil_timerclear(&tv);
44*6777b538SAndroid Build Coastguard Worker tv.tv_sec = 2;
45*6777b538SAndroid Build Coastguard Worker event_add(timeout, &tv);
46*6777b538SAndroid Build Coastguard Worker }
47*6777b538SAndroid Build Coastguard Worker
48*6777b538SAndroid Build Coastguard Worker int
main(int argc,char ** argv)49*6777b538SAndroid Build Coastguard Worker main (int argc, char **argv)
50*6777b538SAndroid Build Coastguard Worker {
51*6777b538SAndroid Build Coastguard Worker struct event timeout;
52*6777b538SAndroid Build Coastguard Worker struct timeval tv;
53*6777b538SAndroid Build Coastguard Worker
54*6777b538SAndroid Build Coastguard Worker /* Initalize the event library */
55*6777b538SAndroid Build Coastguard Worker event_init();
56*6777b538SAndroid Build Coastguard Worker
57*6777b538SAndroid Build Coastguard Worker /* Initalize one event */
58*6777b538SAndroid Build Coastguard Worker evtimer_set(&timeout, timeout_cb, &timeout);
59*6777b538SAndroid Build Coastguard Worker
60*6777b538SAndroid Build Coastguard Worker evutil_timerclear(&tv);
61*6777b538SAndroid Build Coastguard Worker tv.tv_sec = 2;
62*6777b538SAndroid Build Coastguard Worker event_add(&timeout, &tv);
63*6777b538SAndroid Build Coastguard Worker
64*6777b538SAndroid Build Coastguard Worker lasttime = time(NULL);
65*6777b538SAndroid Build Coastguard Worker
66*6777b538SAndroid Build Coastguard Worker event_dispatch();
67*6777b538SAndroid Build Coastguard Worker
68*6777b538SAndroid Build Coastguard Worker return (0);
69*6777b538SAndroid Build Coastguard Worker }
70*6777b538SAndroid Build Coastguard Worker
71