From f0fb9bc5f222a157723e57bc4ae4940cc5c7e803 Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Fri, 15 Jul 2016 17:11:22 +0200 Subject: Add libcoopgamma_set_nonblocking and prototype for libcoopgamma_synchronise MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- src/libcoopgamma.c | 48 +++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 47 insertions(+), 1 deletion(-) (limited to 'src/libcoopgamma.c') diff --git a/src/libcoopgamma.c b/src/libcoopgamma.c index d5c25c7..b26c7b8 100644 --- a/src/libcoopgamma.c +++ b/src/libcoopgamma.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include #include @@ -1274,6 +1275,27 @@ int libcoopgamma_connect(const char* restrict method, const char* restrict site, } +/** + * By default communication is blocking, this function + * can be used to switch between blocking and nonblocking + * + * @param ctx The state of the library, must be connected + * @param nonblocking Nonblocking mode? + * @return Zero on success, -1 on error + */ +int libcoopgamma_set_nonblocking(libcoopgamma_context_t* restrict ctx, int nonblocking) +{ + int flags = fcntl(ctx->fd, F_GETFL); + if (nonblocking) + flags |= O_NONBLOCK; + else + flags &= ~O_NONBLOCK; + if (fcntl(ctx->fd, F_SETFL, flags) == -1) + return -1; + return 0; +} + + /** * Send all pending outbound data * @@ -1283,7 +1305,7 @@ int libcoopgamma_connect(const char* restrict method, const char* restrict site, * be in a properly configured state if a function fails * with EINTR. * - * @param ctx The state of the library, must be initialised + * @param ctx The state of the library, must be connected * @return Zero on success, -1 on error */ int libcoopgamma_flush(libcoopgamma_context_t* restrict ctx) @@ -1312,6 +1334,29 @@ int libcoopgamma_flush(libcoopgamma_context_t* restrict ctx) } +/** + * Wait for the next message to be received + * + * @param ctx The state of the library, must be connected + * @param pending Information for each pending request + * @param n The number of elements in `pending` + * @param selected The index of the element in `pending` which corresponds + * to the first inbound message, note that this only means + * that the message is not for any of the other request, + * if the message is corrupt any of the listed requests can + * be selected even if it is not for any of the requests. + * Functions that parse the message will detect such corruption. + * @return Zero on success, -1 on error, -2 if the message is ignored + * which happens if corresponding `libcoopgamma_async_context_t` + * is not listed + */ +int libcoopgamma_synchronise(libcoopgamma_context_t* restrict ctx, + libcoopgamma_async_context_t* restrict pending, + size_t n, size_t* restrict selected) +{ +} + + /** * Send a message to the server and wait for response * @@ -1522,6 +1567,7 @@ static int check_error(libcoopgamma_context_t* restrict ctx, libcoopgamma_async_ } + /** * List all available CRTC:s, send request part * -- cgit v1.2.3-70-g09d2