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
56
57
58
59
60
61
62
63
64
65
66
67
68
|
/* $Id: event.h 840 2007-09-09 12:17:42Z michael $
* $URL: https://ssl.bulix.org/svn/lcd4linux/trunk/event.h $
*
* generic timer handling
*
* Copyright (C) 2009 Ed Martin <edman007@edman007.com>
* Copyright (C) 2009 The LCD4Linux Team <lcd4linux-devel@users.sourceforge.net>
*
* This file is part of LCD4Linux.
*
* LCD4Linux is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* LCD4Linux is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
*/
#ifndef _EVENT_H_
#define _EVENT_H_
#include <time.h>
//events are identified by their file descriptor only
/*
* these functions allow plugins to add event hooks
* (and thus break out of the main loop when sleeping)
* these callbacks than then trigger named events to propagate
* the event to the screen
*/
typedef enum {
EVENT_READ = 1,
EVENT_WRITE = 2,
EVENT_HUP = 4,
EVENT_ERR = 8
} event_flags_t;
int event_add(void (*callback) (event_flags_t flags, void *data), void *data, const int fd, const int read,
const int write, const int active);
int event_del(const int fd);
int event_modify(const int fd, const int read, const int write, const int active);
int event_process(const struct timespec *timeout);
void event_exit(void);
/*
* These fuctions keep a list of the events to trigger on allowing multiple
* things to trigger an event and multiple things to receive the event
*/
//add an event to be triggered
int named_event_add(char *event, void (*callback) (void *data), void *data);
//remove an event from the list of events
int named_event_del(char *event, void (*callback) (void *data), void *data);
int named_event_trigger(char *event); //call all calbacks for this event
#endif
|