diff options
author | Steven Bethard <steven.bethard@gmail.com> | 2011-03-26 16:57:52 (GMT) |
---|---|---|
committer | Steven Bethard <steven.bethard@gmail.com> | 2011-03-26 16:57:52 (GMT) |
commit | 539586296d64a51cd58c8c45a7dd850cdcc05fcc (patch) | |
tree | 5a44a1f639419f13c571000123ce71c438f77fd5 /Lib/argparse.py | |
parent | 874d59ee91d257702325fc86658203834fb35589 (diff) | |
download | cpython-539586296d64a51cd58c8c45a7dd850cdcc05fcc.zip cpython-539586296d64a51cd58c8c45a7dd850cdcc05fcc.tar.gz cpython-539586296d64a51cd58c8c45a7dd850cdcc05fcc.tar.bz2 |
Issue #9348: Raise an early error if argparse nargs and metavar don't match. (Merge from 3.2.)
Diffstat (limited to 'Lib/argparse.py')
-rw-r--r-- | Lib/argparse.py | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/Lib/argparse.py b/Lib/argparse.py index 8e1722a..d4e691d 100644 --- a/Lib/argparse.py +++ b/Lib/argparse.py @@ -1284,6 +1284,13 @@ class _ActionsContainer(object): if not _callable(type_func): raise ValueError('%r is not callable' % type_func) + # raise an error if the metavar does not match the type + if hasattr(self, "_get_formatter"): + try: + self._get_formatter()._format_args(action, None) + except TypeError: + raise ValueError("length of metavar tuple does not match nargs") + return self._add_action(action) def add_argument_group(self, *args, **kwargs): |