diff options
| author | Victor Stinner <victor.stinner@haypocalc.com> | 2010-09-29 16:35:47 +0000 | 
|---|---|---|
| committer | Victor Stinner <victor.stinner@haypocalc.com> | 2010-09-29 16:35:47 +0000 | 
| commit | c39211f51e377919952b139c46e295800cbc2a8d (patch) | |
| tree | efdb794b06981b5047e699d606b2876e2170b07e /Objects/unicodeobject.c | |
| parent | a5785b1524074656f0a0ec64e5e5cdb27aa3a356 (diff) | |
| download | cpython-git-c39211f51e377919952b139c46e295800cbc2a8d.tar.gz | |
Issue #9630: Redecode filenames when setting the filesystem encoding
Redecode the filenames of:
 - all modules: __file__ and __path__ attributes
 - all code objects: co_filename attribute
 - sys.path
 - sys.meta_path
 - sys.executable
 - sys.path_importer_cache (keys)
Keep weak references to all code objects until initfsencoding() is called, to
be able to redecode co_filename attribute of all code objects.
Diffstat (limited to 'Objects/unicodeobject.c')
| -rw-r--r-- | Objects/unicodeobject.c | 8 | 
1 files changed, 7 insertions, 1 deletions
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index 527e219896..8ceb3f32b8 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -1510,10 +1510,14 @@ PyObject *PyUnicode_EncodeFSDefault(PyObject *unicode)          return PyUnicode_AsEncodedString(unicode,                                           Py_FileSystemDefaultEncoding,                                           "surrogateescape"); -    } else +    } +    else { +        /* if you change the default encoding, update also +           PyUnicode_DecodeFSDefaultAndSize() and redecode_filenames() */          return PyUnicode_EncodeUTF8(PyUnicode_AS_UNICODE(unicode),                                      PyUnicode_GET_SIZE(unicode),                                      "surrogateescape"); +    }  }  PyObject *PyUnicode_AsEncodedString(PyObject *unicode, @@ -1680,6 +1684,8 @@ PyUnicode_DecodeFSDefaultAndSize(const char *s, Py_ssize_t size)                                  "surrogateescape");      }      else { +        /* if you change the default encoding, update also +           PyUnicode_EncodeFSDefault() and redecode_filenames() */          return PyUnicode_DecodeUTF8(s, size, "surrogateescape");      }  }  | 
