diff options
author | Giampaolo Rodola' <g.rodola@gmail.com> | 2012-12-17 13:22:19 (GMT) |
---|---|---|
committer | Giampaolo Rodola' <g.rodola@gmail.com> | 2012-12-17 13:22:19 (GMT) |
commit | 896cb15d0c4a32775cbead257ae85047b5bdba14 (patch) | |
tree | 40046e4af2174f782a7e173043da8fcf6310401f /Lib/ftplib.py | |
parent | 7c42398f3bcc1f9ad1a7ac9e2149754a9e6f334a (diff) | |
parent | fc3278802c51bc8d56bc8a26cc9f95e4f6cfb5bd (diff) | |
download | cpython-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.py | 10 |
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 |