File: timer.c

package info (click to toggle)
libuev 2.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,944 kB
  • sloc: sh: 4,665; ansic: 1,428; makefile: 102
file content (45 lines) | stat: -rw-r--r-- 714 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include "check.h"
#include <time.h>
#include <sys/time.h>

#define TIMEOUT 2		/* 2 sec */

int result = -1;
struct timeval start;

static void cb(uev_t *w, void *arg, int events)
{
	struct timeval now;

	if (UEV_ERROR == events)
		fprintf(stderr, "timer watcher failed, ignoring ...\n");

	gettimeofday(&now, NULL);
	fail_unless(now.tv_sec == start.tv_sec + TIMEOUT);

	result = 0;
	uev_exit(w->ctx);
}

int main(void)
{
	uev_ctx_t ctx;
	uev_t w;
	int rc;

	uev_init(&ctx);
	uev_timer_init(&ctx, &w, cb, NULL, TIMEOUT * 1000, 0);
	gettimeofday(&start, NULL);

	rc = uev_run(&ctx, 0);
	fail_unless(result == 0);

	return rc;
}

/**
 * Local Variables:
 *  indent-tabs-mode: t
 *  c-file-style: "linux"
 * End:
 */