X-Git-Url: http://git.madism.org/?a=blobdiff_plain;f=common%2Fserver.h;h=2757eae2e931c7728024cb51af21444181e07f9d;hb=a07ba1c6e9bc996a8a5f5bd641870259d7f35b99;hp=38289e66d3b6dc5a9a215627e0976f8109c4925e;hpb=bcd90daa5d3d303afe13832249fa20cad7303f8c;p=apps%2Fpfixtools.git diff --git a/common/server.h b/common/server.h index 38289e6..2757eae 100644 --- a/common/server.h +++ b/common/server.h @@ -36,6 +36,7 @@ #ifndef PFIXTOOLS_SERVER_H #define PFIXTOOLS_SERVER_H +#include #include "buffer.h" typedef struct server_t server_t; @@ -46,18 +47,47 @@ typedef void *(*start_client_t)(server_t*); typedef int (*run_client_t)(server_t*, void*); typedef bool (*refresh_t)(void*); +extern struct ev_loop *global_loop; + struct server_t { - unsigned listener : 1; + struct ev_io io; int fd; + buffer_t ibuf; buffer_t obuf; - void* data; + + run_client_t run; delete_client_t clear_data; + void* data; }; +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); + run_client_t runner, refresh_t refresh, void *config); #endif