Commit 195ad6ce authored by Ezio Melotti's avatar Ezio Melotti

#16306: merge with 3.3.

parents 6654de69 f7c709d6
...@@ -7,7 +7,8 @@ import os ...@@ -7,7 +7,8 @@ import os
import sys import sys
import subprocess import subprocess
import tempfile 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 # XXX (ncoghlan): Move to script_helper and make consistent with run_python
...@@ -387,6 +388,12 @@ class CmdLineTest(unittest.TestCase): ...@@ -387,6 +388,12 @@ class CmdLineTest(unittest.TestCase):
assert_python_ok(filename) 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(): def test_main():
test.support.run_unittest(CmdLineTest) test.support.run_unittest(CmdLineTest)
test.support.reap_children() test.support.reap_children()
......
...@@ -837,6 +837,7 @@ Trent Nelson ...@@ -837,6 +837,7 @@ Trent Nelson
Chad Netzer Chad Netzer
Max Neunhöffer Max Neunhöffer
George Neville-Neil George Neville-Neil
Hieu Nguyen
Johannes Nicolai Johannes Nicolai
Samuel Nicolary Samuel Nicolary
Jonathan Niehof Jonathan Niehof
......
...@@ -10,6 +10,9 @@ What's New in Python 3.4.0 Alpha 1? ...@@ -10,6 +10,9 @@ What's New in Python 3.4.0 Alpha 1?
Core and Builtins Core and Builtins
----------------- -----------------
- Issue #16306: Fix multiple error messages when unknown command line
parameters where passed to the interpreter. Patch by Hieu Nguyen.
- Issue #16215: Fix potential double memory free in str.replace(). Patch - Issue #16215: Fix potential double memory free in str.replace(). Patch
by Serhiy Storchaka. by Serhiy Storchaka.
......
...@@ -45,7 +45,7 @@ static wchar_t *opt_ptr = L""; ...@@ -45,7 +45,7 @@ static wchar_t *opt_ptr = L"";
void _PyOS_ResetGetOpt(void) void _PyOS_ResetGetOpt(void)
{ {
_PyOS_opterr = 1; _PyOS_opterr = 0; /* prevent printing the error in 2nd loop in main.c */
_PyOS_optind = 1; _PyOS_optind = 1;
_PyOS_optarg = NULL; _PyOS_optarg = NULL;
opt_ptr = L""; opt_ptr = L"";
...@@ -90,10 +90,11 @@ int _PyOS_GetOpt(int argc, wchar_t **argv, wchar_t *optstring) ...@@ -90,10 +90,11 @@ int _PyOS_GetOpt(int argc, wchar_t **argv, wchar_t *optstring)
opt_ptr = &argv[_PyOS_optind++][1]; opt_ptr = &argv[_PyOS_optind++][1];
} }
if ( (option = *opt_ptr++) == L'\0') if ((option = *opt_ptr++) == L'\0')
return -1; return -1;
if (option == 'J') { if (option == 'J') {
if (_PyOS_opterr)
fprintf(stderr, "-J is reserved for Jython\n"); fprintf(stderr, "-J is reserved for Jython\n");
return '_'; return '_';
} }
...@@ -101,7 +102,6 @@ int _PyOS_GetOpt(int argc, wchar_t **argv, wchar_t *optstring) ...@@ -101,7 +102,6 @@ int _PyOS_GetOpt(int argc, wchar_t **argv, wchar_t *optstring)
if ((ptr = wcschr(optstring, option)) == NULL) { if ((ptr = wcschr(optstring, option)) == NULL) {
if (_PyOS_opterr) if (_PyOS_opterr)
fprintf(stderr, "Unknown option: -%c\n", (char)option); fprintf(stderr, "Unknown option: -%c\n", (char)option);
return '_'; return '_';
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment