summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAntoine Pitrou <solipsis@pitrou.net>2010-03-22 15:12:58 +0000
committerAntoine Pitrou <solipsis@pitrou.net>2010-03-22 15:12:58 +0000
commit498c43866af3ae3496ae8d1aa8a8cfdc5b6a7866 (patch)
treec5155c749294422a5b39aff402034316b04a108c
parent4fd2ff90a4d45b042549ff5919b41ffce3c245e8 (diff)
downloadcpython-git-498c43866af3ae3496ae8d1aa8a8cfdc5b6a7866.tar.gz
Merged revisions 79226 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r79226 | antoine.pitrou | 2010-03-21 20:33:38 +0100 (dim., 21 mars 2010) | 4 lines Issue #3890: Fix recv() and recv_into() on non-blocking SSL sockets. ........
-rw-r--r--Lib/ssl.py26
-rw-r--r--Misc/NEWS2
2 files changed, 8 insertions, 20 deletions
diff --git a/Lib/ssl.py b/Lib/ssl.py
index 40e3e2dff6..58fd2b042d 100644
--- a/Lib/ssl.py
+++ b/Lib/ssl.py
@@ -210,16 +210,9 @@ class SSLSocket(socket):
if self._sslobj:
if flags != 0:
raise ValueError(
- "non-zero flags not allowed in calls to sendall() on %s" %
+ "non-zero flags not allowed in calls to recv() on %s" %
self.__class__)
- while True:
- try:
- return self.read(buflen)
- except SSLError, x:
- if x.args[0] == SSL_ERROR_WANT_READ:
- continue
- else:
- raise x
+ return self.read(buflen)
else:
return socket.recv(self, buflen, flags)
@@ -233,17 +226,10 @@ class SSLSocket(socket):
raise ValueError(
"non-zero flags not allowed in calls to recv_into() on %s" %
self.__class__)
- while True:
- try:
- tmp_buffer = self.read(nbytes)
- v = len(tmp_buffer)
- buffer[:v] = tmp_buffer
- return v
- except SSLError as x:
- if x.args[0] == SSL_ERROR_WANT_READ:
- continue
- else:
- raise x
+ tmp_buffer = self.read(nbytes)
+ v = len(tmp_buffer)
+ buffer[:v] = tmp_buffer
+ return v
else:
return socket.recv_into(self, buffer, nbytes, flags)
diff --git a/Misc/NEWS b/Misc/NEWS
index d4a11dc734..7fcbc17ea3 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -23,6 +23,8 @@ Core and Builtins
Library
-------
+- Issue #3890: Fix recv() and recv_into() on non-blocking SSL sockets.
+
- Issue #6544: fix a reference leak in the kqueue implementation's error
handling.