diff options
Diffstat (limited to 'libxcb/src')
| -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/xcb_auth.c | 7 | ||||
| -rw-r--r-- | libxcb/src/xcb_conn.c | 48 | ||||
| -rw-r--r-- | libxcb/src/xcb_in.c | 6 | ||||
| -rw-r--r-- | libxcb/src/xcb_out.c | 5 | ||||
| -rw-r--r-- | libxcb/src/xcb_util.c | 31 | ||||
| -rw-r--r-- | libxcb/src/xcb_windefs.h | 13 | 
11 files changed, 373 insertions, 21 deletions
| diff --git a/libxcb/src/c_client.py b/libxcb/src/c_client.py index a10b3f1d8..dcf661abc 100644 --- a/libxcb/src/c_client.py +++ b/libxcb/src/c_client.py @@ -172,6 +172,7 @@ def c_open(self):      _c('#include <assert.h>')      _c('#include "xcbext.h"')      _c('#include "%s.h"', _ns.header) +    _c('#include <X11/Xtrans/Xtrans.h>')      if _ns.is_ext:          for (n, h) in self.imports: 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..97705cc24 --- /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 + +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/xcb_auth.c b/libxcb/src/xcb_auth.c index 967ba283a..8a868a4a1 100644 --- a/libxcb/src/xcb_auth.c +++ b/libxcb/src/xcb_auth.c @@ -250,13 +250,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 60475a54d..5593201d5 100644 --- a/libxcb/src/xcb_conn.c +++ b/libxcb/src/xcb_conn.c @@ -47,6 +47,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
 @@ -66,7 +72,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) 
 @@ -106,7 +112,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;
 @@ -174,33 +180,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;
 @@ -375,6 +396,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_in.c b/libxcb/src/xcb_in.c index b4c48fb67..77278742d 100644 --- a/libxcb/src/xcb_in.c +++ b/libxcb/src/xcb_in.c @@ -51,6 +51,12 @@  #define XCB_REPLY 1
  #define XCB_XGE_EVENT 35
 +#ifdef _MSC_VER
 +#ifdef MSG_WAITALL
 +#undef MSG_WAITALL
 +#endif
 +#endif
 +
  /* required for compiling for Win32 using MinGW */
  #ifndef MSG_WAITALL
  #define MSG_WAITALL 0
 diff --git a/libxcb/src/xcb_out.c b/libxcb/src/xcb_out.c index fbce7a0ea..8347c37cd 100644 --- a/libxcb/src/xcb_out.c +++ b/libxcb/src/xcb_out.c @@ -29,6 +29,7 @@  #include <stdlib.h>  #include <unistd.h>  #include <string.h> +#include <X11/Xtrans/Xtrans.h>  #include "xcb.h"  #include "xcbext.h" @@ -239,11 +240,11 @@ unsigned int xcb_send_request(xcb_connection_t *c, int flags, struct iovec *vect          if(prefix[2])          {              prefix[1] = ((uint32_t *) vector[1].iov_base)[0]; -            vector[1].iov_base = (uint32_t *) vector[1].iov_base + 1; +            vector[1].iov_base = (caddr_t)((uint32_t *) vector[1].iov_base + 1);              vector[1].iov_len -= sizeof(uint32_t);          }          vector[0].iov_len = sizeof(uint32_t) * ((prefix[0] ? 1 : 0) + (prefix[2] ? 2 : 0)); -        vector[0].iov_base = prefix + !prefix[0]; +        vector[0].iov_base = (caddr_t)(prefix + !prefix[0]);      }      if(!write_block(c, vector, veclen)) diff --git a/libxcb/src/xcb_util.c b/libxcb/src/xcb_util.c index 6e635f931..e5b874e38 100644 --- a/libxcb/src/xcb_util.c +++ b/libxcb/src/xcb_util.c @@ -54,6 +54,13 @@  #include "xcbext.h"
  #include "xcbint.h"
 +#ifdef _MSC_VER
 +#ifdef close
 +#undef close
 +#endif
 +#define close(fd) closesocket(fd)
 +#endif
 +
  int xcb_popcount(uint32_t mask)
  {
      uint32_t y;
 @@ -298,6 +305,23 @@ static int _xcb_open_decnet(const char *host, const char *protocol, const unsign  }
  #endif
 +#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;
 @@ -337,6 +361,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 */
 @@ -346,7 +375,7 @@ static int _xcb_open_tcp(const char *host, char *protocol, const unsigned short      {
          fd = _xcb_socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
          if(fd >= 0) {
 -            int on = 1;
 +            char on = 1;
              setsockopt(fd, IPPROTO_TCP, TCP_NODELAY, &on, sizeof(on));
  	    setsockopt(fd, SOL_SOCKET, SO_KEEPALIVE, &on, sizeof(on));
 diff --git a/libxcb/src/xcb_windefs.h b/libxcb/src/xcb_windefs.h index a8e9524d6..6b5217de4 100644 --- a/libxcb/src/xcb_windefs.h +++ b/libxcb/src/xcb_windefs.h @@ -31,15 +31,18 @@  #define WINVER 0x0501 /* required for getaddrinfo/freeaddrinfo defined only for WinXP and above */
  #endif
 +#define INCL_WINSOCK_API_TYPEDEFS 1 /* Needed for LPFN_GETPEERNAME */
 +
 +#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 int in_addr_t;
 +#define HANDLE void *
 +typedef int pid_t;
 +
 +#define STDERR_FILENO stderr
 +
  #endif /* xcb_windefs.h */
 | 
