xref: /aosp_15_r20/external/cronet/third_party/libevent/sample/time-test.c (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
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