diff options
| author | Victor Stinner <victor.stinner@haypocalc.com> | 2010-06-11 23:56:51 +0000 | 
|---|---|---|
| committer | Victor Stinner <victor.stinner@haypocalc.com> | 2010-06-11 23:56:51 +0000 | 
| commit | 313a120ab6515f1bcddb13a9403a857078a9e474 (patch) | |
| tree | 7304789294142106cef3076af6249fa611f041e3 /Objects/unicodeobject.c | |
| parent | 0f35e2c0f44b2012e4e32aaccde6fa42756e61f1 (diff) | |
| download | cpython-git-313a120ab6515f1bcddb13a9403a857078a9e474.tar.gz | |
Issue #8969: On Windows, use mbcs codec in strict mode to encode and decode
filenames and enable os.fsencode().
Diffstat (limited to 'Objects/unicodeobject.c')
| -rw-r--r-- | Objects/unicodeobject.c | 14 | 
1 files changed, 10 insertions, 4 deletions
| diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index de92787cc6..8d75b205de 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -1478,11 +1478,17 @@ PyObject *PyUnicode_AsEncodedObject(PyObject *unicode,  PyObject *PyUnicode_EncodeFSDefault(PyObject *unicode)  { -    if (Py_FileSystemDefaultEncoding) +    if (Py_FileSystemDefaultEncoding) { +#if defined(MS_WINDOWS) && defined(HAVE_USABLE_WCHAR_T) +        if (strcmp(Py_FileSystemDefaultEncoding, "mbcs") == 0) +            return PyUnicode_EncodeMBCS(PyUnicode_AS_UNICODE(unicode), +                                        PyUnicode_GET_SIZE(unicode), +                                        NULL); +#endif          return PyUnicode_AsEncodedString(unicode,                                           Py_FileSystemDefaultEncoding,                                           "surrogateescape"); -    else +    } else          return PyUnicode_EncodeUTF8(PyUnicode_AS_UNICODE(unicode),                                       PyUnicode_GET_SIZE(unicode),                                       "surrogateescape"); @@ -1639,7 +1645,7 @@ PyUnicode_DecodeFSDefaultAndSize(const char *s, Py_ssize_t size)      if (Py_FileSystemDefaultEncoding) {  #if defined(MS_WINDOWS) && defined(HAVE_USABLE_WCHAR_T)          if (strcmp(Py_FileSystemDefaultEncoding, "mbcs") == 0) { -            return PyUnicode_DecodeMBCS(s, size, "surrogateescape"); +            return PyUnicode_DecodeMBCS(s, size, NULL);          }  #elif defined(__APPLE__)          if (strcmp(Py_FileSystemDefaultEncoding, "utf-8") == 0) { @@ -2745,7 +2751,7 @@ PyUnicode_DecodeUTF32Stateful(const char *s,  #endif      PyObject *errorHandler = NULL;      PyObject *exc = NULL; -     +      q = (unsigned char *)s;      e = q + size; | 
