From c8d5977bb546dae9ed59d81556639c49badd8121 Mon Sep 17 00:00:00 2001 From: Ondřej Surý Date: Wed, 2 Nov 2011 22:44:12 +0100 Subject: Imported Upstream version 0.8.0~pre1 --- src/common/evqueue.c | 130 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 130 insertions(+) create mode 100644 src/common/evqueue.c (limited to 'src/common/evqueue.c') diff --git a/src/common/evqueue.c b/src/common/evqueue.c new file mode 100644 index 0000000..ca3027f --- /dev/null +++ b/src/common/evqueue.c @@ -0,0 +1,130 @@ +/* Copyright (C) 2011 CZ.NIC, z.s.p.o. + + This program 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 3 of the License, or + (at your option) any later version. + + This program 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, see . + */ + +#include +#include +#include + +#include "common/evqueue.h" + +/*! \brief Singleton application-wide event queue. */ +evqueue_t *s_evqueue = 0; + +evqueue_t *evqueue_new() +{ + evqueue_t* q = malloc(sizeof(evqueue_t)); + + /* Initialize fds. */ + if (pipe(q->fds) < 0) { + free(q); + q = 0; + } + + return q; +} + +void evqueue_free(evqueue_t **q) +{ + /* Check. */ + if (!q) { + return; + } + + /* Invalidate pointer to queue. */ + evqueue_t *eq = *q; + *q = 0; + + /* Deinitialize. */ + close(eq->fds[EVQUEUE_READFD]); + close(eq->fds[EVQUEUE_WRITEFD]); + free(eq); +} + +int evqueue_poll(evqueue_t *q, const struct timespec *ts, + const sigset_t *sigmask) +{ + /* Check. */ + if (!q) { + return -1; + } + + /* Prepare fd set. */ + fd_set rfds; + FD_ZERO(&rfds); + FD_SET(q->fds[EVQUEUE_READFD], &rfds); + + /* Wait for events. */ + int ret = pselect(q->fds[EVQUEUE_READFD] + 1, &rfds, 0, 0, ts, sigmask); + if (ret < 0) { + return -1; + } + + return ret; +} + +int evqueue_read(evqueue_t *q, void *dst, size_t len) +{ + if (!q || !dst || len == 0) { + return -1; + } + + return read(q->fds[EVQUEUE_READFD], dst, len); +} + +int evqueue_write(evqueue_t *q, const void *src, size_t len) +{ + if (!q || !src || len == 0) { + return -1; + } + + return write(q->fds[EVQUEUE_WRITEFD], src, len); +} + +int evqueue_get(evqueue_t *q, event_t *ev) +{ + /* Check. */ + if (!q || !ev) { + return -1; + } + + /* Read data. */ + int ret = evqueue_read(q, ev, sizeof(event_t)); + if (ret != sizeof(event_t)) { + return -1; + } + + /* Set parent. */ + ev->parent = q; + + return 0; +} + +int evqueue_add(evqueue_t *q, const event_t *ev) +{ + /* Check. */ + if (!q || !ev) { + return -1; + } + + /* Write data. */ + int ret = evqueue_write(q, ev, sizeof(event_t)); + if (ret != sizeof(event_t)) { + return -1; + } + + return 0; +} + -- cgit v1.2.3