Skip to content

Commit

Permalink
pythongh-53780: argparse: ignore the first "--" (double dash) between…
Browse files Browse the repository at this point in the history
… an option and command
  • Loading branch information
serhiy-storchaka committed Sep 20, 2024
1 parent baa3550 commit 13ad66c
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 4 deletions.
12 changes: 8 additions & 4 deletions Lib/argparse.py
Original file line number Diff line number Diff line change
Expand Up @@ -2070,11 +2070,15 @@ def consume_positionals(start_index):
# and add the Positional and its args to the list
for action, arg_count in zip(positionals, arg_counts):
args = arg_strings[start_index: start_index + arg_count]
# Strip out the first '--' if it is not in PARSER or REMAINDER arg.
if (action.nargs not in [PARSER, REMAINDER]
and arg_strings_pattern.find('-', start_index,
# Strip out the first '--' if it is not in REMAINDER arg.
if action.nargs == PARSER:
if arg_strings_pattern[start_index] == '-':
assert args[0] == '--'
args.remove('--')
elif action.nargs != REMAINDER:
if (arg_strings_pattern.find('-', start_index,
start_index + arg_count) >= 0):
args.remove('--')
args.remove('--')
start_index += arg_count
if args and action.deprecated and action.dest not in warned:
self._warning(_("argument '%(argument_name)s' is deprecated") %
Expand Down
14 changes: 14 additions & 0 deletions Lib/test/test_argparse.py
Original file line number Diff line number Diff line change
Expand Up @@ -5833,6 +5833,20 @@ def test_subparser(self):
"invalid choice: '--'",
parser.parse_args, ['--', 'x', '--', 'run', 'a', 'b'])

def test_subparser_after_multiple_argument_option(self):
parser = argparse.ArgumentParser(exit_on_error=False)
parser.add_argument('--foo', nargs='*')
subparsers = parser.add_subparsers()
parser1 = subparsers.add_parser('run')
parser1.add_argument('-f')
parser1.add_argument('bar', nargs='*')

args = parser.parse_args(['--foo', 'x', 'y', '--', 'run', 'a', 'b', '-f', 'c'])
self.assertEqual(NS(foo=['x', 'y'], f='c', bar=['a', 'b']), args)
self.assertRaisesRegex(argparse.ArgumentError,
"invalid choice: '--'",
parser.parse_args, ['--foo', 'x', '--', '--', 'run', 'a', 'b'])


# ===========================
# parse_intermixed_args tests
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
:mod:`argparse` now ignores the first ``"--"`` (double dash) between an option and command.

0 comments on commit 13ad66c

Please sign in to comment.