]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
#16306: Fix multiple error messages when unknown command line parameters where passed...
authorEzio Melotti <ezio.melotti@gmail.com>
Sun, 18 Nov 2012 11:46:38 +0000 (13:46 +0200)
committerEzio Melotti <ezio.melotti@gmail.com>
Sun, 18 Nov 2012 11:46:38 +0000 (13:46 +0200)
Lib/test/test_cmd_line.py
Misc/ACKS
Misc/NEWS
Python/getopt.c

index d12caeb0e1cd8357bc2e4cc2a2a7d1a19b015703..b803046c360bbf13f21b33a456fa6c9191befa1b 100644 (file)
@@ -6,7 +6,8 @@ import test.test_support
 import sys
 import unittest
 from test.script_helper import (
-    assert_python_ok, spawn_python, kill_python, python_exit_code
+    assert_python_ok, assert_python_failure, spawn_python, kill_python,
+    python_exit_code
 )
 
 
@@ -116,6 +117,14 @@ class CmdLineTest(unittest.TestCase):
         assert_python_ok(filename)
 
 
+    def test_unknown_options(self):
+        # Add "without='-E'" to prevent _assert_python append env_vars -E
+        # which changes the output of stderr
+        rc, out, err = assert_python_failure('-z', without='-E')
+        self.assertIn(b'Unknown option', err)
+        self.assertEqual(err.splitlines().count(b'Unknown option: -z'), 1)
+        self.assertEqual(b'', out)
+
 def test_main():
     test.test_support.run_unittest(CmdLineTest)
     test.test_support.reap_children()
index 3604dd037293a3e914f02e06f6606ea69c2370a5..462145aa3b65a777b6d980e934df844bf3d6ce77 100644 (file)
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -701,6 +701,7 @@ Tony Nelson
 Chad Netzer
 Max Neunhöffer
 George Neville-Neil
+Hieu Nguyen
 Johannes Nicolai
 Samuel Nicolary
 Gustavo Niemeyer
index f50ed5430642c4d532df14f87c1cb9998a7987a1..b5b7a5042ce373ede439bb50adfd48a6723766bd 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -9,6 +9,9 @@ What's New in Python 2.7.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 #15379: Fix passing of non-BMP characters as integers for the charmap
   decoder (already working as unicode strings).  Patch by Serhiy Storchaka.
 
index e96eb6ccc3d3706d595bada747e2574dccbaba1c..624da9ad895d984aeb0289ebe7d6fd999d3de901 100644 (file)
@@ -41,7 +41,7 @@ static char *opt_ptr = "";
 
 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 = "";
@@ -86,17 +86,19 @@ int _PyOS_GetOpt(int argc, char **argv, char *optstring)
         opt_ptr = &argv[_PyOS_optind++][1];
     }
 
-    if ( (option = *opt_ptr++) == '\0')
+    if ((option = *opt_ptr++) == '\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 (option == 'X') {
-        fprintf(stderr,
-          "-X is reserved for implementation-specific arguments\n");
+        if (_PyOS_opterr)
+            fprintf(stderr,
+                "-X is reserved for implementation-specific arguments\n");
         return '_';
     }
 
@@ -117,7 +119,7 @@ int _PyOS_GetOpt(int argc, char **argv, char *optstring)
             if (_PyOS_optind >= argc) {
                 if (_PyOS_opterr)
                     fprintf(stderr,
-                "Argument expected for the -%c option\n", option);
+                        "Argument expected for the -%c option\n", option);
                 return '_';
             }