]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Fix issue #16646: ftplib.FTP.makeport() might lose socket error details. (patch...
authorGiampaolo Rodola' <g.rodola@gmail.com>
Mon, 17 Dec 2012 13:30:48 +0000 (14:30 +0100)
committerGiampaolo Rodola' <g.rodola@gmail.com>
Mon, 17 Dec 2012 13:30:48 +0000 (14:30 +0100)
Lib/ftplib.py
Misc/NEWS

index c8964330bfcfb9262c568513f5655488be6a1269..53b5f44c52deec3d1eac5041d0bca2cdd1b6c4b1 100644 (file)
@@ -273,21 +273,24 @@ class FTP:
 
     def makeport(self):
         '''Create a new socket and send a PORT command for it.'''
-        msg = "getaddrinfo returns an empty list"
+        err = None
         sock = None
         for res in socket.getaddrinfo(None, 0, self.af, socket.SOCK_STREAM, 0, socket.AI_PASSIVE):
             af, socktype, proto, canonname, sa = res
             try:
                 sock = socket.socket(af, socktype, proto)
                 sock.bind(sa)
-            except socket.error, msg:
+            except socket.error, err:
                 if sock:
                     sock.close()
                 sock = None
                 continue
             break
-        if not sock:
-            raise socket.error, msg
+        if sock is None:
+            if err is not None:
+                raise err
+            else:
+                raise socket.error("getaddrinfo returns an empty list")
         sock.listen(1)
         port = sock.getsockname()[1] # Get proper port
         host = self.sock.getsockname()[0] # Get proper host
index 4e6e6610741b5e8ad7f6d036ed32e8fd9f0103dd..8f5460aaaaee188ee9c7ce027278bf7e2eb28a13 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -160,6 +160,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #16646: ftplib.FTP.makeport() might lose socket error details.
+  (patch by Serhiy Storchaka)
+
 - Issue #16626: Fix infinite recursion in glob.glob() on Windows when the
   pattern contains a wildcard in the drive or UNC path.  Patch by Serhiy
   Storchaka.