[Python-checkins] r85435 - in python/branches/py3k: Misc/NEWS Modules/python.c

victor.stinner python-checkins at python.org
Thu Oct 14 00:15:07 CEST 2010


Author: victor.stinner
Date: Thu Oct 14 00:15:06 2010
New Revision: 85435

Log:
Issue #9992: On Mac OS X, decode command line arguments from utf-8 instead of
the locale encoding.


Modified:
   python/branches/py3k/Misc/NEWS
   python/branches/py3k/Modules/python.c

Modified: python/branches/py3k/Misc/NEWS
==============================================================================
--- python/branches/py3k/Misc/NEWS	(original)
+++ python/branches/py3k/Misc/NEWS	Thu Oct 14 00:15:06 2010
@@ -10,6 +10,9 @@
 Core and Builtins
 -----------------
 
+- Issue #9992: On Mac OS X, decode command line arguments from utf-8 instead of
+  the locale encoding.
+
 - Issue #9992: Remove PYTHONFSENCODING environment variable.
 
 Library

Modified: python/branches/py3k/Modules/python.c
==============================================================================
--- python/branches/py3k/Modules/python.c	(original)
+++ python/branches/py3k/Modules/python.c	Thu Oct 14 00:15:06 2010
@@ -41,7 +41,15 @@
     oldloc = strdup(setlocale(LC_ALL, NULL));
     setlocale(LC_ALL, "");
     for (i = 0; i < argc; i++) {
-        argv_copy2[i] = argv_copy[i] = _Py_char2wchar(argv[i]);
+#ifdef __APPLE__
+        /* Use utf-8 on Mac OS X */
+        PyObject *unicode = PyUnicode_FromString(argv[i]);
+        argv_copy[i] = PyUnicode_AsWideCharString(unicode, NULL);
+        Py_DECREF(unicode);
+#else
+        argv_copy[i] = _Py_char2wchar(argv[i]);
+#endif
+        argv_copy2[i] = argv_copy[i];
         if (!argv_copy[i])
             return 1;
     }


More information about the Python-checkins mailing list