X-Git-Url: http://git.madism.org/?a=blobdiff_plain;f=common%2Fserver.h;h=2757eae2e931c7728024cb51af21444181e07f9d;hb=a07ba1c6e9bc996a8a5f5bd641870259d7f35b99;hp=33d7157630975e581376be843c8c4b8cd2a41b43;hpb=6deab7a7086ccb592daa0c41e12759ec0b9c7aa0;p=apps%2Fpfixtools.git diff --git a/common/server.h b/common/server.h index 33d7157..2757eae 100644 --- a/common/server.h +++ b/common/server.h @@ -36,22 +36,21 @@ #ifndef PFIXTOOLS_SERVER_H #define PFIXTOOLS_SERVER_H +#include #include "buffer.h" typedef struct server_t server_t; -#define INVALID_EVENT (NULL) - typedef void *(*start_listener_t)(void); 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 bool (*event_handler_t)(server_t *, void*); -struct server_t { - unsigned listener : 1; +extern struct ev_loop *global_loop; +struct server_t { + struct ev_io io; int fd; buffer_t ibuf; @@ -66,8 +65,28 @@ ARRAY(server_t); int start_server(int port, start_listener_t starter, delete_client_t deleter); server_t *server_register(int fd, run_client_t runner, void *data); +void server_delete(server_t **server); void server_release(server_t *server); +static inline void server_none(server_t *server) +{ + ev_io_stop(global_loop, &server->io); +} + +static inline void server_rw(server_t *server) +{ + ev_io_stop(global_loop, &server->io); + ev_io_set(&server->io, server->fd, EV_READ | EV_WRITE); + ev_io_start(global_loop, &server->io); +} + +static inline void server_ro(server_t *server) +{ + ev_io_stop(global_loop, &server->io); + ev_io_set(&server->io, server->fd, EV_READ); + ev_io_start(global_loop, &server->io); +} + int server_loop(start_client_t starter, delete_client_t deleter, run_client_t runner, refresh_t refresh, void *config);