#12353: argparse now correctly handles null argument values.

Patch by Torsten Landschoff.
This commit is contained in:
R David Murray 2012-07-21 22:35:00 -04:00
parent 1a2c1fbfd2
commit 056c31f9cc
3 changed files with 4 additions and 1 deletions

View File

@ -1967,7 +1967,7 @@ class ArgumentParser(_AttributeHolder, _ActionsContainer):
for arg_string in arg_strings: for arg_string in arg_strings:
# for regular arguments, just add them back into the list # for regular arguments, just add them back into the list
if arg_string[0] not in self.fromfile_prefix_chars: if not arg_string or arg_string[0] not in self.fromfile_prefix_chars:
new_arg_strings.append(arg_string) new_arg_strings.append(arg_string)
# replace arguments referencing files with the file content # replace arguments referencing files with the file content

View File

@ -1374,6 +1374,7 @@ class TestArgumentsFromFile(TempDirMixin, ParserTestCase):
('X @hello', NS(a=None, x='X', y=['hello world!'])), ('X @hello', NS(a=None, x='X', y=['hello world!'])),
('-a B @recursive Y Z', NS(a='A', x='hello world!', y=['Y', 'Z'])), ('-a B @recursive Y Z', NS(a='A', x='hello world!', y=['Y', 'Z'])),
('X @recursive Z -a B', NS(a='B', x='X', y=['hello world!', 'Z'])), ('X @recursive Z -a B', NS(a='B', x='X', y=['hello world!', 'Z'])),
(["-a", "", "X", "Y"], NS(a='', x='X', y=['Y'])),
] ]

View File

@ -90,6 +90,8 @@ Core and Builtins
Library Library
------- -------
- Issue #12353: argparse now correctly handles null argument values.
- Issue #6493: An issue in ctypes on Windows that caused structure bitfields - Issue #6493: An issue in ctypes on Windows that caused structure bitfields
of type ctypes.c_uint32 and width 32 to incorrectly be set has been fixed. of type ctypes.c_uint32 and width 32 to incorrectly be set has been fixed.