Skip to content

Commit

Permalink
python#16306: Fix multiple error messages when unknown command line p…
Browse files Browse the repository at this point in the history
…arameters where passed to the interpreter. Patch by Hieu Nguyen.
  • Loading branch information
ezio-melotti committed Nov 18, 2012
1 parent 6a5fc4c commit 7c66319
Show file tree
Hide file tree
Showing 4 changed files with 17 additions and 6 deletions.
9 changes: 8 additions & 1 deletion Lib/test/test_cmd_line.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,8 @@
import sys
import subprocess
import tempfile
from test.script_helper import spawn_python, kill_python, assert_python_ok, assert_python_failure
from test.script_helper import (spawn_python, kill_python, assert_python_ok,
assert_python_failure)


# XXX (ncoghlan): Move to script_helper and make consistent with run_python
Expand Down Expand Up @@ -376,6 +377,12 @@ def test_del___main__(self):
assert_python_ok(filename)


def test_unknown_options(self):
rc, out, err = assert_python_failure('-z', __cleanenv=True)
self.assertIn(b'Unknown option', err)
self.assertEqual(err.splitlines().count(b'Unknown option: -z'), 1)
self.assertEqual(b'', out)

def test_main():
test.support.run_unittest(CmdLineTest)
test.support.reap_children()
Expand Down
1 change: 1 addition & 0 deletions Misc/ACKS
Original file line number Diff line number Diff line change
Expand Up @@ -757,6 +757,7 @@ Tony Nelson
Chad Netzer
Max Neunhöffer
George Neville-Neil
Hieu Nguyen
Johannes Nicolai
Samuel Nicolary
Gustavo Niemeyer
Expand Down
3 changes: 3 additions & 0 deletions Misc/NEWS
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,9 @@ What's New in Python 3.2.4
Core and Builtins
-----------------

- Issue #16306: Fix multiple error messages when unknown command line
parameters where passed to the interpreter. Patch by Hieu Nguyen.

- Issue #16453: Fix equality testing of dead weakref objects.

- Issue #9535: Fix pending signals that have been received but not yet
Expand Down
10 changes: 5 additions & 5 deletions Python/getopt.c
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ static wchar_t *opt_ptr = L"";

void _PyOS_ResetGetOpt(void)
{
_PyOS_opterr = 1;
_PyOS_opterr = 0; /* prevent printing the error in 2nd loop in main.c */
_PyOS_optind = 1;
_PyOS_optarg = NULL;
opt_ptr = L"";
Expand Down Expand Up @@ -90,18 +90,18 @@ int _PyOS_GetOpt(int argc, wchar_t **argv, wchar_t *optstring)
opt_ptr = &argv[_PyOS_optind++][1];
}

if ( (option = *opt_ptr++) == L'\0')
if ((option = *opt_ptr++) == L'\0')
return -1;

if (option == 'J') {
fprintf(stderr, "-J is reserved for Jython\n");
if (_PyOS_opterr)
fprintf(stderr, "-J is reserved for Jython\n");
return '_';
}

if ((ptr = wcschr(optstring, option)) == NULL) {
if (_PyOS_opterr)
fprintf(stderr, "Unknown option: -%c\n", (char)option);

fprintf(stderr, "Unknown option: -%c\n", (char)option);
return '_';
}

Expand Down

0 comments on commit 7c66319

Please sign in to comment.