aboutsummaryrefslogtreecommitdiffstats
path: root/xenlog.c
blob: d5ab4d0160a66b564a608a90df6618ad4614a02b (plain)
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
52
53
54
55
#include <stdio.h>
#include <stdlib.h>

#include <xs.h>

/* ------------------------------------------------------------- */

int main(int argc, char *argv[])
{
    struct xs_handle  *xenstore;
    struct xs_transaction_handle *xst;
    char *xs_value = NULL, **vec;
    char *value;
    unsigned int count;

    xenstore = xs_daemon_open_readonly();
    if (NULL == xenstore) {
	fprintf(stderr,"can't connect to %s\n",xs_daemon_socket_ro());
	exit(1);
    }
    xs_watch(xenstore, "/", "token");

    for (;;) {
	vec = xs_read_watch(xenstore, &count);
	if (NULL == vec) {
	    fprintf(stderr,"xs_read_watch() failed\n");
	    exit(1);
	}
	switch (vec[XS_WATCH_PATH][0]) {
	case '/':
	    xst = xs_transaction_start(xenstore);
	    if (NULL != xst) {
		xs_value = xs_read(xenstore, xst, vec[XS_WATCH_PATH], NULL);
		xs_transaction_end(xenstore, xst, 0);
		if (NULL == xs_value)
		    value = "<deleted>";
		else
		    value = xs_value;
	    } else {
		value = "<error>";
	    }
	    break;
	default:
	    value = "<null>";
	    break;
	}
	fprintf(stderr,"%-64s :  \"%s\"\n", vec[XS_WATCH_PATH], value);

	if (xs_value) {
	    free(xs_value);
	    xs_value = NULL;
	}
	free(vec);
    }
}