ref: 4ce926cb7eab2e349a38840b765b77587649fbdf
parent: 25477092988deb11338abe8002f3ef76afac068c
author: Timothy B. Terriberry <[email protected]>
date: Wed Jan 9 11:01:35 EST 2013
Fix warnings when compiling with a recent MSVC. Apparently Vista includes more things in its Winsock implementation and errno.h than earlier versions of Windows.
--- a/src/http.c
+++ b/src/http.c
@@ -214,18 +214,31 @@
# define OP_INVALID_SOCKET (INVALID_SOCKET)
+/*Vista and later support WSAPoll(), but we don't want to rely on that.
+ Instead we re-implement it badly using select().
+ Unfortunately, they define a conflicting struct pollfd, so we only define our
+ own if it looks like that one has not already been defined.*/
+# if !defined(POLLIN)
+/*Equivalent to POLLIN.*/
+# define POLLRDNORM (0x0100)
+/*Priority band data can be read.*/
+# define POLLRDBAND (0x0200)
/*There is data to read.*/
-# define POLLIN (0x0001)
+# define POLLIN (POLLRDNORM|POLLRDBAND)
/* There is urgent data to read.*/
-# define POLLPRI (0x0002)
+# define POLLPRI (0x0400)
+/*Equivalent to POLLOUT.*/
+# define POLLWRNORM (0x0010)
/*Writing now will not block.*/
-# define POLLOUT (0x0004)
+# define POLLOUT (POLLWRNORM)
+/*Priority data may be written.*/
+# define POLLWRBAND (0x0020)
/*Error condition (output only).*/
-# define POLLERR (0x0008)
+# define POLLERR (0x0001)
/*Hang up (output only).*/
-# define POLLHUP (0x0010)
+# define POLLHUP (0x0002)
/*Invalid request: fd not open (output only).*/
-# define POLLNVAL (0x0020)
+# define POLLNVAL (0x0004)
struct pollfd{
/*File descriptor.*/
@@ -235,11 +248,12 @@
/*Returned events.*/
short revents;
};
+# endif
+/*But Winsock never defines nfds_t (it's simply hard-coded to ULONG).*/
typedef unsigned long nfds_t;
-/*Winsock has no poll(), so we reimplement it (badly) using select().
- The usage of FD_SET() below is O(N^2).
+/*The usage of FD_SET() below is O(N^2).
This is okay because select() is limited to 64 sockets in Winsock, anyway.
In practice, we only ever call it with one or two sockets.*/
static int op_poll_win32(struct pollfd *_fds,nfds_t _nfds,int _timeout){
@@ -295,6 +309,10 @@
# define setsockopt(_fd,_level,_name,_val,_len) \
setsockopt(_fd,_level,_name,(const char *)(_val),_len)
# define poll(_fds,_nfds,_timeout) op_poll_win32(_fds,_nfds,_timeout)
+
+# if defined(_MSC_VER)
+typedef ptrdiff_t ssize_t;
+# endif
# else
/*Normal Berkeley sockets.*/
--- a/src/winerrno.h
+++ b/src/winerrno.h
@@ -15,9 +15,38 @@
# include <errno.h>
# include <winerror.h>
-/*These conflict with the MSVC errno definitions, but we don't need to use the
- original ones in any file that deals with sockets.*/
+/*These conflict with the MSVC errno.h definitions, but we don't need to use
+ the original ones in any file that deals with sockets.
+ We could map the WSA errors to the errno.h ones (most of which are only
+ available on sufficiently new versions of MSVC), but they aren't ordered the
+ same, and given how rarely we actually look at the values, I don't think
+ it's worth a lookup table.*/
+# undef EWOULDBLOCK
+# undef EINPROGRESS
+# undef EALREADY
+# undef ENOTSOCK
+# undef EDESTADDRREQ
+# undef EMSGSIZE
+# undef EPROTOTYPE
+# undef ENOPROTOOPT
+# undef EPROTONOSUPPORT
+# undef EOPTNOTSUPP
+# undef EAFNOSUPPORT
+# undef EADDRINUSE
+# undef EADDRNOTAVAIL
+# undef ENETDOWN
+# undef ENETUNREACH
+# undef ENETRESET
+# undef ECONNABORTED
+# undef ECONNRESET
+# undef ENOBUFS
+# undef EISCONN
+# undef ENOTCONN
+# undef ETIMEDOUT
+# undef ECONNREFUSED
+# undef ELOOP
# undef ENAMETOOLONG
+# undef EHOSTUNREACH
# undef ENOTEMPTY
# define EWOULDBLOCK (WSAEWOULDBLOCK-WSABASEERR)