summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2016-07-22 15:47:09 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2016-07-22 15:47:09 (GMT)
commitd3afb62b8fb38417c3f0bf6873ed64bd9efd8e43 (patch)
tree98d248b4db1e4febc04224095ce4a594fd37ac99 /Modules
parent5e1989ce899d4afa937977b30a7b2fe9c0bf085c (diff)
parent524714eeda70de01046e3b4736516f41d7d11010 (diff)
downloadcpython-d3afb62b8fb38417c3f0bf6873ed64bd9efd8e43.zip
cpython-d3afb62b8fb38417c3f0bf6873ed64bd9efd8e43.tar.gz
cpython-d3afb62b8fb38417c3f0bf6873ed64bd9efd8e43.tar.bz2
Merge 3.5 (INVALID_SOCKET)
Diffstat (limited to 'Modules')
-rw-r--r--Modules/_ssl.c8
-rw-r--r--Modules/socketmodule.c12
2 files changed, 12 insertions, 8 deletions
diff --git a/Modules/_ssl.c b/Modules/_ssl.c
index 0e979e0..8a4654a 100644
--- a/Modules/_ssl.c
+++ b/Modules/_ssl.c
@@ -113,6 +113,10 @@ struct py_ssl_library_code {
# define HAVE_ALPN
#endif
+#ifndef INVALID_SOCKET /* MS defines this */
+#define INVALID_SOCKET (-1)
+#endif
+
enum py_ssl_error {
/* these mirror ssl.h */
PY_SSL_ERROR_NONE,
@@ -1699,7 +1703,7 @@ PySSL_select(PySocketSockObject *s, int writing, _PyTime_t timeout)
}
/* Guard against closed socket */
- if (s->sock_fd < 0)
+ if (s->sock_fd == INVALID_SOCKET)
return SOCKET_HAS_BEEN_CLOSED;
/* Prefer poll, if available, since you can poll() any fd
@@ -2023,7 +2027,7 @@ _ssl__SSLSocket_shutdown_impl(PySSLSocket *self)
if (sock != NULL) {
/* Guard against closed socket */
- if ((((PyObject*)sock) == Py_None) || (sock->sock_fd < 0)) {
+ if ((((PyObject*)sock) == Py_None) || (sock->sock_fd == INVALID_SOCKET)) {
_setSSLError("Underlying socket connection gone",
PY_SSL_ERROR_NO_SOCKET, __FILE__, __LINE__);
return NULL;
diff --git a/Modules/socketmodule.c b/Modules/socketmodule.c
index f8d39f6..d21d18f 100644
--- a/Modules/socketmodule.c
+++ b/Modules/socketmodule.c
@@ -2579,8 +2579,8 @@ sock_close(PySocketSockObject *s)
int res;
fd = s->sock_fd;
- if (fd != -1) {
- s->sock_fd = -1;
+ if (fd != INVALID_SOCKET) {
+ s->sock_fd = INVALID_SOCKET;
/* We do not want to retry upon EINTR: see
http://lwn.net/Articles/576478/ and
@@ -2606,7 +2606,7 @@ static PyObject *
sock_detach(PySocketSockObject *s)
{
SOCKET_T fd = s->sock_fd;
- s->sock_fd = -1;
+ s->sock_fd = INVALID_SOCKET;
return PyLong_FromSocket_t(fd);
}
@@ -4202,7 +4202,7 @@ sock_finalize(PySocketSockObject *s)
/* Save the current exception, if any. */
PyErr_Fetch(&error_type, &error_value, &error_traceback);
- if (s->sock_fd != -1) {
+ if (s->sock_fd != INVALID_SOCKET) {
if (PyErr_ResourceWarning((PyObject *)s, 1, "unclosed %R", s)) {
/* Spurious errors can appear at shutdown */
if (PyErr_ExceptionMatches(PyExc_Warning)) {
@@ -4215,7 +4215,7 @@ sock_finalize(PySocketSockObject *s)
socket.getsockname(). If the socket is closed before, socket
methods fails with the EBADF error. */
fd = s->sock_fd;
- s->sock_fd = -1;
+ s->sock_fd = INVALID_SOCKET;
/* We do not want to retry upon EINTR: see sock_close() */
Py_BEGIN_ALLOW_THREADS
@@ -4275,7 +4275,7 @@ sock_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
new = type->tp_alloc(type, 0);
if (new != NULL) {
- ((PySocketSockObject *)new)->sock_fd = -1;
+ ((PySocketSockObject *)new)->sock_fd = INVALID_SOCKET;
((PySocketSockObject *)new)->sock_timeout = _PyTime_FromSeconds(-1);
((PySocketSockObject *)new)->errorhandler = &set_error;
}