File: event-test.c

package info (click to toggle)
gsocket 1.4.43-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,224 kB
  • sloc: ansic: 14,009; sh: 3,629; makefile: 155
file content (51 lines) | stat: -rw-r--r-- 1,112 bytes parent folder | download | duplicates (2)
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
46
47
48
49
50
51
#include "gs-common.h"
#include <gsocket/gsocket.h>
#include "gs-externs.h"

static int
cb_event(void *ptr)
{
#ifdef DEBUG
	GS_EVENT *event = (GS_EVENT *)ptr;
#endif

	DEBUGF("Event callback...(data = '%s', len = %zd)\n", (char *)event->data, event->len);

	return 0;
}


int
main(int argc, char *argv[])
{
	GS_EVENT_MGR mgr;
	GS_EVENT my_e;
	GS_EVENT *my_e_ptr;

	GS_library_init(stderr, stderr, NULL);
	srand(time(NULL));

	GS_EVENT_MGR_init(&mgr);

	my_e_ptr = GS_EVENT_add_by_ts(&mgr, NULL, 0, GS_SEC_TO_USEC(1), cb_event, "foobar", 7);
	// Every 2 seconds return to caller
	my_e_ptr = GS_EVENT_add_by_ts(&mgr, NULL, 0, GS_SEC_TO_USEC(2), NULL, "caller-action", 7);
	GS_EVENT_add_by_ts(&mgr, &my_e, 0, GS_MSEC_TO_USEC(437), cb_event, "foobar500", 31337);

	if (my_e_ptr == NULL)
		ERREXIT("add_by_ts()\n");
	uint64_t wait;
	while (1)
	{
		wait = GS_EVENT_execute(&mgr);
		DEBUGF_G("Next event in %"PRIu64" usec\n", wait);
		if (mgr.is_return_to_caller)
			DEBUGF_C("Return to caller triggered\n");
		usleep(wait);
		// GS_EVENT_del(my_e_ptr);
		// my_e_ptr = NULL;
		// GS_EVENT_DEL(&my_e);
	}

	return 0;
}