mirror of
https://github.com/python/cpython.git
synced 2025-07-23 11:15:24 +00:00
[3.13] gh-81691: Fix handling of multiple "--" (double dashes) in argparse (GH-124233) (GH-124266)
Only the first one has now been removed, all subsequent ones are now
taken literally.
(cherry picked from commit aae126748f
)
Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
This commit is contained in:
parent
6fe746d702
commit
63870162f4
3 changed files with 67 additions and 8 deletions
|
@ -5784,7 +5784,30 @@ class TestParseKnownArgs(TestCase):
|
|||
self.assertEqual(NS(x=[]), args)
|
||||
|
||||
def test_double_dash(self):
|
||||
parser = argparse.ArgumentParser()
|
||||
parser = argparse.ArgumentParser(exit_on_error=False)
|
||||
parser.add_argument('-f', '--foo')
|
||||
parser.add_argument('bar', nargs='*')
|
||||
|
||||
args = parser.parse_args(['--foo=--'])
|
||||
self.assertEqual(NS(foo='--', bar=[]), args)
|
||||
self.assertRaisesRegex(argparse.ArgumentError,
|
||||
'argument -f/--foo: expected one argument',
|
||||
parser.parse_args, ['--foo', '--'])
|
||||
args = parser.parse_args(['-f--'])
|
||||
self.assertEqual(NS(foo='--', bar=[]), args)
|
||||
self.assertRaisesRegex(argparse.ArgumentError,
|
||||
'argument -f/--foo: expected one argument',
|
||||
parser.parse_args, ['-f', '--'])
|
||||
args = parser.parse_args(['--foo', 'a', '--', 'b', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
|
||||
args = parser.parse_args(['a', 'b', '--foo', 'c'])
|
||||
self.assertEqual(NS(foo='c', bar=['a', 'b']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', '--foo', 'c'])
|
||||
self.assertEqual(NS(foo=None, bar=['a', 'b', '--foo', 'c']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', '--', 'c', '--foo', 'd'])
|
||||
self.assertEqual(NS(foo=None, bar=['a', 'b', '--', 'c', '--foo', 'd']), args)
|
||||
|
||||
parser = argparse.ArgumentParser(exit_on_error=False)
|
||||
parser.add_argument('-f', '--foo', nargs='*')
|
||||
parser.add_argument('bar', nargs='*')
|
||||
|
||||
|
@ -5798,6 +5821,41 @@ class TestParseKnownArgs(TestCase):
|
|||
self.assertEqual(NS(foo=[], bar=[]), args)
|
||||
args = parser.parse_args(['--foo', 'a', 'b', '--', 'c', 'd'])
|
||||
self.assertEqual(NS(foo=['a', 'b'], bar=['c', 'd']), args)
|
||||
args = parser.parse_args(['a', 'b', '--foo', 'c', 'd'])
|
||||
self.assertEqual(NS(foo=['c', 'd'], bar=['a', 'b']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', '--foo', 'c', 'd'])
|
||||
self.assertEqual(NS(foo=None, bar=['a', 'b', '--foo', 'c', 'd']), args)
|
||||
args, argv = parser.parse_known_args(['a', 'b', '--foo', 'c', '--', 'd'])
|
||||
self.assertEqual(NS(foo=['c'], bar=['a', 'b']), args)
|
||||
self.assertEqual(argv, ['--', 'd'])
|
||||
|
||||
parser = argparse.ArgumentParser(exit_on_error=False)
|
||||
parser.add_argument('foo')
|
||||
parser.add_argument('bar', nargs='*')
|
||||
|
||||
args = parser.parse_args(['--', 'a', 'b', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
|
||||
args = parser.parse_args(['a', 'b', '--', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', '--', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', '--', 'c']), args)
|
||||
args = parser.parse_args(['--', '--', 'a', '--', 'b', 'c'])
|
||||
self.assertEqual(NS(foo='--', bar=['a', '--', 'b', 'c']), args)
|
||||
|
||||
parser = argparse.ArgumentParser(exit_on_error=False)
|
||||
parser.add_argument('foo')
|
||||
parser.add_argument('bar', nargs=argparse.REMAINDER)
|
||||
|
||||
args = parser.parse_args(['--', 'a', 'b', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
|
||||
args = parser.parse_args(['a', 'b', '--', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', '--', 'c']), args)
|
||||
args = parser.parse_args(['a', '--', 'b', '--', 'c'])
|
||||
self.assertEqual(NS(foo='a', bar=['b', '--', 'c']), args)
|
||||
|
||||
|
||||
# ===========================
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue