projects
/
apps
/
pfixtools.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Basic support for async filters.
[apps/pfixtools.git]
/
common
/
server.h
diff --git
a/common/server.h
b/common/server.h
index
dfa7eb0
..
85cbae4
100644
(file)
--- a/
common/server.h
+++ b/
common/server.h
@@
-39,7
+39,6
@@
#include "buffer.h"
typedef struct server_t server_t;
#include "buffer.h"
typedef struct server_t server_t;
-typedef server_t *event_t;
#define INVALID_EVENT (NULL)
#define INVALID_EVENT (NULL)
@@
-48,7
+47,7
@@
typedef void (*delete_client_t)(void*);
typedef void *(*start_client_t)(server_t*);
typedef int (*run_client_t)(server_t*, void*);
typedef bool (*refresh_t)(void*);
typedef void *(*start_client_t)(server_t*);
typedef int (*run_client_t)(server_t*, void*);
typedef bool (*refresh_t)(void*);
-typedef bool (*event_handler_t)(
event_t
, void*);
+typedef bool (*event_handler_t)(
server_t *
, void*);
struct server_t {
unsigned listener : 1;
struct server_t {
unsigned listener : 1;
@@
-67,8
+66,12
@@
ARRAY(server_t);
int start_server(int port, start_listener_t starter, delete_client_t deleter);
int start_server(int port, start_listener_t starter, delete_client_t deleter);
-event_t event_register(void *data);
-bool event_fire(event_t event);
+void server_release(server_t *server);
+
+server_t *event_register(int fd, void *data);
+bool event_fire(server_t *event);
+bool event_cancel(server_t *event);
+void event_release(server_t *event);
#define event_data(event) ((event)->data)
int server_loop(start_client_t starter, delete_client_t deleter,
#define event_data(event) ((event)->data)
int server_loop(start_client_t starter, delete_client_t deleter,