diff options
Diffstat (limited to 'libxcb/src')
| -rw-r--r-- | libxcb/src/.gitignore | 56 | ||||
| -rw-r--r-- | libxcb/src/c_client.py | 1 | ||||
| -rw-r--r-- | libxcb/src/config.h | 80 | ||||
| -rw-r--r-- | libxcb/src/dummyin6.h | 168 | ||||
| -rw-r--r-- | libxcb/src/makefile | 22 | ||||
| -rw-r--r-- | libxcb/src/makefile.srcs | 13 | ||||
| -rw-r--r-- | libxcb/src/man/.gitignore | 1 | ||||
| -rw-r--r-- | libxcb/src/xcb_auth.c | 7 | ||||
| -rw-r--r-- | libxcb/src/xcb_conn.c | 48 | ||||
| -rw-r--r-- | libxcb/src/xcb_ext.c | 2 | ||||
| -rw-r--r-- | libxcb/src/xcb_in.c | 1 | ||||
| -rw-r--r-- | libxcb/src/xcb_out.c | 7 | ||||
| -rw-r--r-- | libxcb/src/xcb_util.c | 31 | ||||
| -rw-r--r-- | libxcb/src/xcb_windefs.h | 15 | ||||
| -rw-r--r-- | libxcb/src/xcb_xid.c | 2 | 
15 files changed, 433 insertions, 21 deletions
| diff --git a/libxcb/src/.gitignore b/libxcb/src/.gitignore new file mode 100644 index 000000000..dd0db52df --- /dev/null +++ b/libxcb/src/.gitignore @@ -0,0 +1,56 @@ +bigreq.c
 +bigreq.h
 +composite.c
 +composite.h
 +damage.c
 +damage.h
 +dpms.c
 +dpms.h
 +dri2.c
 +dri2.h
 +ge.c
 +ge.h
 +glx.c
 +glx.h
 +randr.c
 +randr.h
 +record.c
 +record.h
 +render.c
 +render.h
 +res.c
 +res.h
 +screensaver.c
 +screensaver.h
 +shape.c
 +shape.h
 +shm.c
 +shm.h
 +sync.c
 +sync.h
 +xc_misc.c
 +xc_misc.h
 +xevie.c
 +xevie.h
 +xf86dri.c
 +xf86dri.h
 +xf86vidmode.c
 +xf86vidmode.h
 +xfixes.c
 +xfixes.h
 +xinerama.c
 +xinerama.h
 +xinput.c
 +xinput.h
 +xprint.c
 +xprint.h
 +xproto.c
 +xproto.h
 +xselinux.c
 +xselinux.h
 +xtest.c
 +xtest.h
 +xv.c
 +xv.h
 +xvmc.c
 +xvmc.h
\ No newline at end of file diff --git a/libxcb/src/c_client.py b/libxcb/src/c_client.py index d006d305d..cbd235659 100644 --- a/libxcb/src/c_client.py +++ b/libxcb/src/c_client.py @@ -181,6 +181,7 @@ def c_open(self):      _c('#include <stddef.h>  /* for offsetof() */')      _c('#include "xcbext.h"')      _c('#include "%s.h"', _ns.header) +    _c('#include <X11/Xtrans/Xtrans.h>')      _c('')      _c('#define ALIGNOF(type) offsetof(struct { char dummy; type member; }, member)') diff --git a/libxcb/src/config.h b/libxcb/src/config.h new file mode 100644 index 000000000..6c701936c --- /dev/null +++ b/libxcb/src/config.h @@ -0,0 +1,80 @@ +/* src/config.h.in.  Generated from configure.ac by autoheader.  */ + +/* Defined if GCC supports the visibility feature */ +#undef GCC_HAS_VISIBILITY + +/* Has Wraphelp.c needed for XDM AUTH protocols */ +#undef HASXDMAUTH + +/* Define if your platform supports abstract sockets */ +#undef HAVE_ABSTRACT_SOCKETS + +/* Define to 1 if you have the <dlfcn.h> header file. */ +#undef HAVE_DLFCN_H + +/* Define to 1 if you have the <inttypes.h> header file. */ +#undef HAVE_INTTYPES_H + +/* launchd support available */ +#undef HAVE_LAUNCHD + +/* Define to 1 if you have the <memory.h> header file. */ +#undef HAVE_MEMORY_H + +/* Have the sockaddr_un.sun_len member. */ +#undef HAVE_SOCKADDR_SUN_LEN + +/* Define to 1 if you have the <stdint.h> header file. */ +#undef HAVE_STDINT_H + +/* Define to 1 if you have the <stdlib.h> header file. */ +#undef HAVE_STDLIB_H + +/* Define to 1 if you have the <strings.h> header file. */ +#undef HAVE_STRINGS_H + +/* Define to 1 if you have the <string.h> header file. */ +#undef HAVE_STRING_H + +/* Define to 1 if you have the <sys/stat.h> header file. */ +#undef HAVE_SYS_STAT_H + +/* Define to 1 if you have the <sys/types.h> header file. */ +#undef HAVE_SYS_TYPES_H + +/* Define to 1 if you have the <unistd.h> header file. */ +#define HAVE_UNISTD_H + +/* Define to the sub-directory in which libtool stores uninstalled libraries. +   */ +#undef LT_OBJDIR + +/* Name of package */ +#undef PACKAGE + +/* Define to the address where bug reports for this package should be sent. */ +#undef PACKAGE_BUGREPORT + +/* Define to the full name of this package. */ +#undef PACKAGE_NAME + +/* Define to the full name and version of this package. */ +#undef PACKAGE_STRING + +/* Define to the one symbol short name of this package. */ +#undef PACKAGE_TARNAME + +/* Define to the version of this package. */ +#undef PACKAGE_VERSION + +/* Define to 1 if you have the ANSI C header files. */ +#undef STDC_HEADERS + +/* poll() function is available */ +#undef USE_POLL + +/* Version number of package */ +#undef VERSION + +/* XCB buffer queue size */ +#define XCB_QUEUE_BUFFER_SIZE 4096 diff --git a/libxcb/src/dummyin6.h b/libxcb/src/dummyin6.h new file mode 100644 index 000000000..b86b250e4 --- /dev/null +++ b/libxcb/src/dummyin6.h @@ -0,0 +1,168 @@ +/* + * Copyright (c) 2001, 2003  Motoyuki Kasahara + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + *    notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + *    notice, this list of conditions and the following disclaimer in the + *    documentation and/or other materials provided with the distribution. + * 3. Neither the name of the project nor the names of its contributors + *    may be used to endorse or promote products derived from this software + *    without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED.  IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#ifndef DUMMYIN6_H +#define DUMMYIN6_H + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <sys/types.h> + +#include <sys/socket.h> +#include <netinet/in.h> +#include <netdb.h> + +#ifndef AF_INET6 +#define AF_INET6 (AF_INET + 1) +#endif + +#ifndef PF_INET6 +#define PF_INET6 (PF_INET + 1) +#endif + +#ifndef AF_UNSPEC +#define AF_UNSPEC AF_INET +#endif + +#ifndef PF_UNSPEC +#define PF_UNSPEC PF_INET +#endif + +#ifndef INET6_ADDRSTRLEN +#define INET6_ADDRSTRLEN	46 +#endif + +#ifndef INET_ADDRSTRLEN +#define INET_ADDRSTRLEN		16 +#endif + +#ifndef HAVE_STRUCT_IN6_ADDR +struct in6_addr { +    unsigned char	s6_addr[16]; +}; +#endif + +#ifndef HAVE_STRUCT_SOCKADDR_IN6 +struct sockaddr_in6 { +    sa_family_t		sin6_family; +    in_port_t		sin6_port; +    unsigned long	sin6_flowinfo; +    struct in6_addr	sin6_addr; +    unsigned long	sin6_scope_id; +}; +#endif + +#if !defined(HAVE_STRUCT_SOCKADDR_STORAGE) && !defined(sockaddr_storage) +#define sockaddr_storage sockaddr_in +#endif + +#ifndef IN6ADDR_ANY_DECLARED +extern const struct in6_addr in6addr_any; +#endif + +#ifndef IN6ADDR_LOOPBACK_DECLARED +extern const struct in6_addr in6addr_loopback; +#endif + +#ifndef IN6ADDR_ANY_INIT +#define IN6ADDR_ANY_INIT \ +	{{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \ +	  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}} +#endif + +#ifndef IN6ADDR_LOOPBACK_INIT +#define IN6ADDR_LOOPBACK_INIT \ +	{{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, \ +	  0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01}} +#endif + +#ifndef IN6_IS_ADDR_UNSPECIFIED +#define IN6_IS_ADDR_UNSPECIFIED(a) \ +	(   (a)->s6_addr[ 0] == 0 && (a)->s6_addr[ 1] == 0 \ +	 && (a)->s6_addr[ 2] == 0 && (a)->s6_addr[ 3] == 0 \ +	 && (a)->s6_addr[ 4] == 0 && (a)->s6_addr[ 5] == 0 \ +	 && (a)->s6_addr[ 6] == 0 && (a)->s6_addr[ 7] == 0 \ +	 && (a)->s6_addr[ 8] == 0 && (a)->s6_addr[ 9] == 0 \ +	 && (a)->s6_addr[10] == 0 && (a)->s6_addr[11] == 0 \ +	 && (a)->s6_addr[12] == 0 && (a)->s6_addr[13] == 0 \ +	 && (a)->s6_addr[14] == 0 && (a)->s6_addr[15] == 0) +#endif + +#ifndef IN6_IS_ADDR_LOOPBACK +#define IN6_IS_ADDR_LOOPBACK(a) \ +	(   (a)->s6_addr[ 0] == 0 && (a)->s6_addr[ 1] == 0 \ +	 && (a)->s6_addr[ 2] == 0 && (a)->s6_addr[ 3] == 0 \ +	 && (a)->s6_addr[ 4] == 0 && (a)->s6_addr[ 5] == 0 \ +	 && (a)->s6_addr[ 6] == 0 && (a)->s6_addr[ 7] == 0 \ +	 && (a)->s6_addr[ 8] == 0 && (a)->s6_addr[ 9] == 0 \ +	 && (a)->s6_addr[10] == 0 && (a)->s6_addr[11] == 0 \ +	 && (a)->s6_addr[12] == 0 && (a)->s6_addr[13] == 0 \ +	 && (a)->s6_addr[14] == 0 && (a)->s6_addr[15] == 1) +#endif + +#ifndef IN6_IS_ADDR_MULTICAST +#define IN6_IS_ADDR_MULTICAST(a) \ +	((a)->s6_addr[0] == 0xff) +#endif + +#ifndef IN6_IS_ADDR_LINKLOCAL +#define IN6_IS_ADDR_LINKLOCAL(a) \ +	(((a)->s6_addr[0] == 0xfe) && (((a)->s6_addr[1] & 0xc0) == 0x80)) +#endif + +#ifndef IN6_IS_ADDR_SITELOCAL +#define IN6_IS_ADDR_SITELOCAL(a) \ +	(((a)->s6_addr[0] == 0xfe) && (((a)->s6_addr[1] & 0xc0) == 0xc0)) +#endif + +#ifndef IN6_IS_ADDR_V4MAPPED +#define IN6_IS_ADDR_V4MAPPED(a) \ +	(   (a)->s6_addr[ 0] == 0    && (a)->s6_addr[ 1] == 0 \ +	 && (a)->s6_addr[ 2] == 0    && (a)->s6_addr[ 3] == 0 \ +	 && (a)->s6_addr[ 4] == 0    && (a)->s6_addr[ 5] == 0 \ +	 && (a)->s6_addr[ 6] == 0    && (a)->s6_addr[ 7] == 0 \ +	 && (a)->s6_addr[ 8] == 0    && (a)->s6_addr[ 9] == 0 \ +	 && (a)->s6_addr[10] == 0xff && (a)->s6_addr[11] == 0xff) +#endif + +#ifndef IN6_IS_ADDR_V4COMPAT +#define IN6_IS_ADDR_V4COMPAT(a) \ +	(   (a)->s6_addr[ 0] == 0 && (a)->s6_addr[ 1] == 0 \ +	 && (a)->s6_addr[ 2] == 0 && (a)->s6_addr[ 3] == 0 \ +	 && (a)->s6_addr[ 4] == 0 && (a)->s6_addr[ 5] == 0 \ +	 && (a)->s6_addr[ 6] == 0 && (a)->s6_addr[ 7] == 0 \ +	 && (a)->s6_addr[ 8] == 0 && (a)->s6_addr[ 9] == 0 \ +	 && (a)->s6_addr[10] == 0 && (a)->s6_addr[11] == 0 \ +	 && ((a)->s6_addr[12] != 0 || (a)->s6_addr[13] != 0 \ +	     || (a)->s6_addr[14] != 0 \ +	     || ((a)->s6_addr[15] != 0 && (a)->s6_addr[15] != 1))) +#endif + +#endif /* not DUMMYIN6_H */ diff --git a/libxcb/src/makefile b/libxcb/src/makefile new file mode 100644 index 000000000..8205311c6 --- /dev/null +++ b/libxcb/src/makefile @@ -0,0 +1,22 @@ + +LIBRARY=libxcb + +CSRCS = \ +		xcb_conn.c xcb_out.c xcb_in.c xcb_ext.c xcb_xid.c \ +		xcb_list.c xcb_util.c xcb_auth.c + +DEFINES += PTW32_STATIC_LIB HAVE_GETADDRINFO + +XCBPROTO_XCBINCLUDEDIR = ..\xcb-proto\src + +XMLFILES := $(notdir $(wildcard $(XCBPROTO_XCBINCLUDEDIR)\*.xml)) +XMLFILES := $(filter-out xkb.xml, $(XMLFILES)) + +EXTSOURCES := $(XMLFILES:%.xml=%.c) +CSRCS += $(EXTSOURCES) + +EXTHEADERS = $(XMLFILES:%.xml=%.h) + +$(EXTHEADERS) $(EXTSOURCES): c_client.py + +load_makefile NORELDBG=1 makefile.srcs diff --git a/libxcb/src/makefile.srcs b/libxcb/src/makefile.srcs new file mode 100644 index 000000000..2d4846a89 --- /dev/null +++ b/libxcb/src/makefile.srcs @@ -0,0 +1,13 @@ +ifneq ($(NORELDBG),1) +$(error NORELDBG should have been set to 1) +endif + +XCBPROTO_XCBPYTHONDIR = ..\xcb-proto +XCBPROTO_XCBINCLUDEDIR = ..\xcb-proto\src + +%.h: $(XCBPROTO_XCBINCLUDEDIR)\%.xml +	python c_client.py -p $(XCBPROTO_XCBPYTHONDIR) $< + +%.c: $(XCBPROTO_XCBINCLUDEDIR)\%.xml +	python c_client.py -p $(XCBPROTO_XCBPYTHONDIR) $< + diff --git a/libxcb/src/man/.gitignore b/libxcb/src/man/.gitignore new file mode 100644 index 000000000..dd0f0cdc7 --- /dev/null +++ b/libxcb/src/man/.gitignore @@ -0,0 +1 @@ +*.3
 diff --git a/libxcb/src/xcb_auth.c b/libxcb/src/xcb_auth.c index a5b730c0c..0514a77e7 100644 --- a/libxcb/src/xcb_auth.c +++ b/libxcb/src/xcb_auth.c @@ -265,13 +265,14 @@ static int compute_auth(xcb_auth_info_t *info, Xauth *authptr, struct sockaddr *  /* `sockaddr_un.sun_path' typical size usually ranges between 92 and 108 */  #define INITIAL_SOCKNAME_SLACK 108 +#ifndef WIN32 +typedef int (*LPFN_GETPEERNAME)(int,struct sockaddr *,socklen_t *); +#endif  /* Return a dynamically allocated socket address structure according     to the value returned by either getpeername() or getsockname()     (according to POSIX, applications should not assume a particular     length for `sockaddr_un.sun_path') */ -static struct sockaddr *get_peer_sock_name(int (*socket_func)(int, -							      struct sockaddr *, -							      socklen_t *), +static struct sockaddr *get_peer_sock_name(LPFN_GETPEERNAME socket_func,  					   int fd)  {      socklen_t socknamelen = sizeof(struct sockaddr) + INITIAL_SOCKNAME_SLACK; diff --git a/libxcb/src/xcb_conn.c b/libxcb/src/xcb_conn.c index 725502af6..ed6f06bdd 100644 --- a/libxcb/src/xcb_conn.c +++ b/libxcb/src/xcb_conn.c @@ -48,6 +48,12 @@  #include <netinet/in.h>  #endif /* _WIN32 */ +#include <X11/Xtrans/Xtrans.h> + +#ifdef _MSC_VER +#define _close(fd) closesocket(fd) +#endif +  /* SHUT_RDWR is fairly recent and is not available on all platforms */  #if !defined(SHUT_RDWR)  #define SHUT_RDWR 2 @@ -69,7 +75,7 @@ static int set_fd_flags(const int fd)  #ifdef _WIN32     u_long iMode = 1; /* non-zero puts it in non-blocking mode, 0 in blocking mode */    -   int ret = 0; +   int ret;     ret = ioctlsocket(fd, FIONBIO, &iMode);     if(ret != 0)  @@ -109,7 +115,7 @@ static int write_setup(xcb_connection_t *c, xcb_auth_info_t *auth_info)      out.authorization_protocol_name_len = 0;      out.authorization_protocol_data_len = 0;      parts[count].iov_len = sizeof(xcb_setup_request_t); -    parts[count++].iov_base = &out; +    parts[count++].iov_base = (caddr_t) &out;      parts[count].iov_len = XCB_PAD(sizeof(xcb_setup_request_t));      parts[count++].iov_base = (char *) pad; @@ -177,33 +183,48 @@ static int read_setup(xcb_connection_t *c)  static int write_vec(xcb_connection_t *c, struct iovec **vector, int *count)  {      int n; -    assert(!c->out.queue_len);  #ifdef _WIN32      int i = 0; -    int ret = 0,err = 0; +    int cnt=*count;      struct iovec *vec;      n = 0; +    assert(!c->out.queue_len);      /* Could use the WSASend win32 function for scatter/gather i/o but setting up the WSABUF struct from         an iovec would require more work and I'm not sure of the benefit....works for now */      vec = *vector; -    while(i < *count) +    while(i < cnt)      {         	  -         ret = send(c->fd,vec->iov_base,vec->iov_len,0);	  +      char *p= vec->iov_base; +      size_t l= vec->iov_len; +      while (l > 0) +      { +         int ret = send(c->fd, p, l, 0);            if(ret == SOCKET_ERROR)           { -             err  = WSAGetLastError(); +             int err  = WSAGetLastError();               if(err == WSAEWOULDBLOCK)               { -                 return 1; +                 if (n) +                 { +                   /* already return the data */ +                   i=cnt; +                   break; +                 } +                 else +                   return 1;               }           } +         p += ret; +         l -= ret;           n += ret; -         *vec++; -         i++; +      } +      vec++; +      i++;      }  #else +    assert(!c->out.queue_len);      n = writev(c->fd, *vector, *count);      if(n < 0 && errno == EAGAIN)          return 1; @@ -407,6 +428,13 @@ int _xcb_conn_wait(xcb_connection_t *c, pthread_cond_t *cond, struct iovec **vec          }  #else          ret = select(c->fd + 1, &rfds, &wfds, 0, 0); +	if (ret==SOCKET_ERROR) +	{ +	   ret=-1; +           errno = WSAGetLastError(); +	   if (errno == WSAEINTR) +		   errno=EINTR; +	}  #endif      } while (ret == -1 && errno == EINTR);      if(ret < 0) diff --git a/libxcb/src/xcb_ext.c b/libxcb/src/xcb_ext.c index 68bb29bdf..c79c54de2 100644 --- a/libxcb/src/xcb_ext.c +++ b/libxcb/src/xcb_ext.c @@ -119,6 +119,8 @@ int _xcb_ext_init(xcb_connection_t *c)  void _xcb_ext_destroy(xcb_connection_t *c)  { +    if (!c->ext.lock) +      return; /* mutex is not initialised */      pthread_mutex_destroy(&c->ext.lock);      while(c->ext.extensions_size-- > 0)          if(c->ext.extensions[c->ext.extensions_size].tag == LAZY_FORCED) diff --git a/libxcb/src/xcb_in.c b/libxcb/src/xcb_in.c index 4998cdda3..d7db8235e 100644 --- a/libxcb/src/xcb_in.c +++ b/libxcb/src/xcb_in.c @@ -51,6 +51,7 @@  #define XCB_REPLY 1  #define XCB_XGE_EVENT 35 +  struct event_list {      xcb_generic_event_t *event;      struct event_list *next; diff --git a/libxcb/src/xcb_out.c b/libxcb/src/xcb_out.c index c0601f270..c082c98ab 100644 --- a/libxcb/src/xcb_out.c +++ b/libxcb/src/xcb_out.c @@ -29,13 +29,14 @@  #include <stdlib.h>  #include <unistd.h>  #include <string.h> +#include <X11/Xtrans/Xtrans.h>  #include "xcb.h"  #include "xcbext.h"  #include "xcbint.h"  #include "bigreq.h" -static inline void send_request(xcb_connection_t *c, int isvoid, enum workarounds workaround, int flags, struct iovec *vector, int count) +static __inline void send_request(xcb_connection_t *c, int isvoid, enum workarounds workaround, int flags, struct iovec *vector, int count)  {      if(c->has_error)          return; @@ -213,10 +214,10 @@ unsigned int xcb_send_request(xcb_connection_t *c, int flags, struct iovec *vect          {              prefix[0] = ((uint32_t *) vector[0].iov_base)[0];              prefix[1] = ++longlen; -            vector[0].iov_base = (uint32_t *) vector[0].iov_base + 1; +            vector[0].iov_base = (caddr_t)((uint32_t *) vector[0].iov_base + 1);              vector[0].iov_len -= sizeof(uint32_t);              --vector, ++veclen; -            vector[0].iov_base = prefix; +            vector[0].iov_base = (caddr_t)prefix;              vector[0].iov_len = sizeof(prefix);          }      } diff --git a/libxcb/src/xcb_util.c b/libxcb/src/xcb_util.c index 45f66cbfe..065fe1407 100644 --- a/libxcb/src/xcb_util.c +++ b/libxcb/src/xcb_util.c @@ -57,6 +57,13 @@  # include <sys/stat.h>  #endif +#ifdef _MSC_VER +#ifdef close +#undef close +#endif +#define close(fd) closesocket(fd) +#endif +  int xcb_popcount(uint32_t mask)  {      uint32_t y; @@ -265,7 +272,7 @@ static int _xcb_socket(int family, int type, int proto)  static int _xcb_do_connect(int fd, const struct sockaddr* addr, int addrlen) { -	int on = 1; +	char on = 1;  	if(fd < 0)  		return -1; @@ -276,6 +283,23 @@ static int _xcb_do_connect(int fd, const struct sockaddr* addr, int addrlen) {  	return connect(fd, addr, addrlen);  } +#ifdef WIN32 +int InitWSA(void) +{ +  static WSADATA wsadata; + +  if (!wsadata.wVersion) +  { +    ptw32_processInitialize(); +    if (WSAStartup(0x0202, &wsadata)) +      return -1; +  } +  return 0; +} +#else +#define InitWSA() +#endif +  static int _xcb_open_tcp(const char *host, char *protocol, const unsigned short port)  {      int fd = -1; @@ -315,6 +339,11 @@ static int _xcb_open_tcp(const char *host, char *protocol, const unsigned short      }  #endif +#ifdef WIN32 +    if (InitWSA()<0) +      return -1; +#endif +      snprintf(service, sizeof(service), "%hu", port);      if(getaddrinfo(host, service, &hints, &results))          /* FIXME: use gai_strerror, and fill in error connection */ diff --git a/libxcb/src/xcb_windefs.h b/libxcb/src/xcb_windefs.h index a8e9524d6..9789735f2 100644 --- a/libxcb/src/xcb_windefs.h +++ b/libxcb/src/xcb_windefs.h @@ -31,15 +31,22 @@  #define WINVER 0x0501 /* required for getaddrinfo/freeaddrinfo defined only for WinXP and above */
  #endif
 +#define INCL_WINSOCK_API_TYPEDEFS 1 /* Needed for LPFN_GETPEERNAME */
 +
 +#define FD_SETSIZE 1024
 +
 +#include <X11/Xwinsock.h>
  #include <winsock2.h>
  #include <ws2tcpip.h>
  #include <windef.h>
 -struct iovec  {
 -    void *iov_base;	/* Pointer to data.  */
 -    int iov_len;	/* Length of data.  */ 
 -};
 +typedef unsigned char BYTE;
  typedef unsigned int in_addr_t;
 +#define HANDLE void *
 +typedef int pid_t;
 +
 +#define STDERR_FILENO 2
 +
  #endif /* xcb_windefs.h */
 diff --git a/libxcb/src/xcb_xid.c b/libxcb/src/xcb_xid.c index 3df5dbec6..b0de73f21 100644 --- a/libxcb/src/xcb_xid.c +++ b/libxcb/src/xcb_xid.c @@ -93,5 +93,7 @@ int _xcb_xid_init(xcb_connection_t *c)  void _xcb_xid_destroy(xcb_connection_t *c)  { +    if (!c->xid.lock) +      return; /* mutex was not initialised yet */      pthread_mutex_destroy(&c->xid.lock);  } | 
