diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2010-03-22 14:49:10 +0000 |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-03-22 14:49:10 +0000 |
commit | 5733c08f55e9bf1ff5ac79908d941581feafea57 (patch) | |
tree | f0f7d64783ed07d6804f63cef4999b9d2d634a4e /Lib/ssl.py | |
parent | 808fc0a0eea56dd4ef2fa9f9dee00ef0c20760f2 (diff) | |
download | cpython-git-5733c08f55e9bf1ff5ac79908d941581feafea57.tar.gz |
Merged revisions 79226,79286 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.
........
r79286 | antoine.pitrou | 2010-03-22 15:41:48 +0100 (lun., 22 mars 2010) | 3 lines
Fix an occasional test_ftplib failure, following r79226.
........
Diffstat (limited to 'Lib/ssl.py')
-rw-r--r-- | Lib/ssl.py | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/Lib/ssl.py b/Lib/ssl.py index b1cc149d87..e009697164 100644 --- a/Lib/ssl.py +++ b/Lib/ssl.py @@ -240,16 +240,9 @@ class SSLSocket(socket): if self._sslobj: if flags != 0: raise ValueError( - "non-zero flags not allowed in calls to recv_into() on %s" % - self.__class__) - while True: - try: - return self.read(buflen) - except SSLError as x: - if x.args[0] == SSL_ERROR_WANT_READ: - continue - else: - raise x + "non-zero flags not allowed in calls to recv() on %s" % + self.__class__) + return self.read(buflen) else: return socket.recv(self, buflen, flags) @@ -273,6 +266,7 @@ class SSLSocket(socket): continue else: raise x + return self.read(nbytes, buffer) else: return socket.recv_into(self, buffer, nbytes, flags) |