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.
........
This commit is contained in:
Antoine Pitrou 2010-03-22 15:12:58 +00:00
parent 4fd2ff90a4
commit 498c43866a
2 changed files with 8 additions and 20 deletions

View File

@ -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)

View File

@ -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.