summaryrefslogtreecommitdiffstats
path: root/Lib/ftplib.py
diff options
context:
space:
mode:
authorGiampaolo Rodola' <g.rodola@gmail.com>2012-12-17 13:22:19 (GMT)
committerGiampaolo Rodola' <g.rodola@gmail.com>2012-12-17 13:22:19 (GMT)
commit896cb15d0c4a32775cbead257ae85047b5bdba14 (patch)
tree40046e4af2174f782a7e173043da8fcf6310401f /Lib/ftplib.py
parent7c42398f3bcc1f9ad1a7ac9e2149754a9e6f334a (diff)
parentfc3278802c51bc8d56bc8a26cc9f95e4f6cfb5bd (diff)
downloadcpython-896cb15d0c4a32775cbead257ae85047b5bdba14.zip
cpython-896cb15d0c4a32775cbead257ae85047b5bdba14.tar.gz
cpython-896cb15d0c4a32775cbead257ae85047b5bdba14.tar.bz2
Fix issue #16646: ftplib.FTP.makeport() might lose socket error details. (patch by Serhiy Storchaka)
Diffstat (limited to 'Lib/ftplib.py')
-rw-r--r--Lib/ftplib.py10
1 files changed, 7 insertions, 3 deletions
diff --git a/Lib/ftplib.py b/Lib/ftplib.py
index 18887a6..490f900 100644
--- a/Lib/ftplib.py
+++ b/Lib/ftplib.py
@@ -288,20 +288,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 as msg:
+ except socket.error as err:
if sock:
sock.close()
sock = None
continue
break
- if not sock:
+ if sock is None:
+ if err is not None:
+ raise err
+ else:
+ raise socket.error("getaddrinfo returns an empty list")
raise socket.error(msg)
sock.listen(1)
port = sock.getsockname()[1] # Get proper port