X-Git-Url: http://git.demorecorder.com/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fxcbint.h;h=b25f03b3ea7d524ad023e5b08edb649ffcc64abf;hb=414b1037c5a9770270022e62aa66fe7a4021a96b;hp=4a01f6ffebe9e1b528d5ef1d59cb26b43838ab7d;hpb=7983bf0fbdc2725403f9db6154d0f5bc944040e5;p=free-sw%2Fxcb%2Flibxcb diff --git a/src/xcbint.h b/src/xcbint.h index 4a01f6f..b25f03b 100644 --- a/src/xcbint.h +++ b/src/xcbint.h @@ -34,10 +34,6 @@ #include "config.h" #endif -#if HAVE_SENDMSG -#include -#endif - #ifdef GCC_HAS_VISIBILITY #pragma GCC visibility push(hidden) #endif @@ -83,13 +79,10 @@ void *_xcb_map_remove(_xcb_map *q, unsigned int key); /* xcb_out.c */ -typedef void (*xcb_return_socket_func_t)(void *closure); - #if HAVE_SENDMSG #define XCB_MAX_PASS_FD 16 typedef struct _xcb_fd { - struct cmsghdr cmsghdr; int fd[XCB_MAX_PASS_FD]; int nfd; int ifd; @@ -100,9 +93,10 @@ typedef struct _xcb_out { pthread_cond_t cond; int writing; - xcb_return_socket_func_t return_socket; + pthread_cond_t socket_cond; + void (*return_socket)(void *closure); void *socket_closure; - unsigned int socket_seq; + int socket_moving; char queue[XCB_QUEUE_BUFFER_SIZE]; int queue_len; @@ -154,6 +148,7 @@ typedef struct _xcb_in { #if HAVE_SENDMSG _xcb_fd in_fd; #endif + struct xcb_special_event *special_events; } _xcb_in; int _xcb_in_init(_xcb_in *in);