summaryrefslogtreecommitdiffstats
path: root/Lib/os.py
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2010-04-25 22:39:07 (GMT)
committerVictor Stinner <victor.stinner@haypocalc.com>2010-04-25 22:39:07 (GMT)
commita27dcb76ee05397108271547b340c977d52ecabb (patch)
tree02a6ca89b7ec422ba38442dda8b465f7e99ff53e /Lib/os.py
parente3123915297da3e87f6d62c0e0788a6b5421a5cf (diff)
downloadcpython-a27dcb76ee05397108271547b340c977d52ecabb.zip
cpython-a27dcb76ee05397108271547b340c977d52ecabb.tar.gz
cpython-a27dcb76ee05397108271547b340c977d52ecabb.tar.bz2
Merged revisions 80421,80424 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r80421 | victor.stinner | 2010-04-23 23:41:56 +0200 (ven., 23 avril 2010) | 3 lines Issue #8391: os.execvpe() and os.getenv() supports unicode with surrogates and bytes strings for environment keys and values ........ r80424 | victor.stinner | 2010-04-24 00:55:39 +0200 (sam., 24 avril 2010) | 13 lines Fix test_undecodable_env of test_subproces for non-ASCII directory This test was introduced by r80421 (issue #8391). The fix: copy the environment variables instead of starting Python in an empty environement. In an empty environment, the locale is C and Python uses ASCII for the default file system encoding. The non-ASCII directory will be encoded using surrogates, but Python3 is unable to load a module or package with a filename using surrogates. See issue #8242 for more information about running Python3 with a non-ascii directory in an empty environement. ........
Diffstat (limited to 'Lib/os.py')
-rw-r--r--Lib/os.py2
1 files changed, 2 insertions, 0 deletions
diff --git a/Lib/os.py b/Lib/os.py
index d72f32b..aa1a40f 100644
--- a/Lib/os.py
+++ b/Lib/os.py
@@ -443,6 +443,8 @@ environ = _Environ(environ, _keymap, _putenv, _unsetenv)
def getenv(key, default=None):
"""Get an environment variable, return None if it doesn't exist.
The optional second argument can specify an alternate default."""
+ if isinstance(key, bytes):
+ key = key.decode(sys.getfilesystemencoding(), "surrogateescape")
return environ.get(key, default)
__all__.append("getenv")