summaryrefslogtreecommitdiff
path: root/Lib/argparse.py
diff options
context:
space:
mode:
authorSteven Bethard <steven.bethard@gmail.com>2011-01-24 20:40:15 +0000
committerSteven Bethard <steven.bethard@gmail.com>2011-01-24 20:40:15 +0000
commitf8583acb534432097671e79eb4110b9861dd2e17 (patch)
tree1287cc0567d1e65b5b6edfc868a5fa0f577f7cff /Lib/argparse.py
parentcdb8388cad74e0f2910d5b43531daf6271467292 (diff)
downloadcpython-git-f8583acb534432097671e79eb4110b9861dd2e17.tar.gz
Issue #9509: make argarse properly handle IOErrors raised by argparse.FileType. Approved by Georg in the tracker.
Diffstat (limited to 'Lib/argparse.py')
-rw-r--r--Lib/argparse.py13
1 files changed, 7 insertions, 6 deletions
diff --git a/Lib/argparse.py b/Lib/argparse.py
index 78f4dcb228..75cc28a043 100644
--- a/Lib/argparse.py
+++ b/Lib/argparse.py
@@ -1109,7 +1109,7 @@ class FileType(object):
the builtin open() function.
"""
- def __init__(self, mode='r', bufsize=None):
+ def __init__(self, mode='r', bufsize=-1):
self._mode = mode
self._bufsize = bufsize
@@ -1125,14 +1125,15 @@ class FileType(object):
raise ValueError(msg)
# all other arguments are used as file names
- if self._bufsize:
+ try:
return open(string, self._mode, self._bufsize)
- else:
- return open(string, self._mode)
+ except IOError as e:
+ message = _("can't open '%s': %s")
+ raise ArgumentTypeError(message % (string, e))
def __repr__(self):
- args = [self._mode, self._bufsize]
- args_str = ', '.join([repr(arg) for arg in args if arg is not None])
+ args = self._mode, self._bufsize
+ args_str = ', '.join(repr(arg) for arg in args if arg != -1)
return '%s(%s)' % (type(self).__name__, args_str)
# ===========================