Merged revisions 83116 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r83116 | victor.stinner | 2010-07-24 02:49:20 +0200 (sam., 24 juil. 2010) | 4 lines Issue #4629: getopt raises an error if an argument ends with = whereas getopt doesn't except a value (eg. --help= is rejected if getopt uses ['help='] long options). ........
This commit is contained in:
parent
cdbd099ca0
commit
4c16d122c4
|
@ -155,7 +155,7 @@ def do_longs(opts, opt, longopts, args):
|
|||
if not args:
|
||||
raise GetoptError('option --%s requires argument' % opt, opt)
|
||||
optarg, args = args[0], args[1:]
|
||||
elif optarg:
|
||||
elif optarg is not None:
|
||||
raise GetoptError('option --%s must not have an argument' % opt, opt)
|
||||
opts.append(('--' + opt, optarg or ''))
|
||||
return opts, args
|
||||
|
|
|
@ -173,6 +173,12 @@ class GetoptTests(unittest.TestCase):
|
|||
m = types.ModuleType("libreftest", s)
|
||||
run_doctest(m, verbose)
|
||||
|
||||
def test_issue4629(self):
|
||||
longopts, shortopts = getopt.getopt(['--help='], '', ['help='])
|
||||
self.assertEquals(longopts, [('--help', '')])
|
||||
longopts, shortopts = getopt.getopt(['--help=x'], '', ['help='])
|
||||
self.assertEquals(longopts, [('--help', 'x')])
|
||||
self.assertRaises(getopt.GetoptError, getopt.getopt, ['--help='], '', ['help'])
|
||||
|
||||
def test_main():
|
||||
run_unittest(GetoptTests)
|
||||
|
|
|
@ -18,6 +18,10 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #4629: getopt raises an error if an argument ends with = whereas getopt
|
||||
doesn't except a value (eg. --help= is rejected if getopt uses ['help='] long
|
||||
options).
|
||||
|
||||
- Issue #7895: platform.mac_ver() no longer crashes after calling os.fork()
|
||||
|
||||
- Issue #5395: array.fromfile() would raise a spurious EOFError when an
|
||||
|
|
Loading…
Reference in New Issue