mirror of
https://github.com/python/cpython.git
synced 2025-08-31 14:07:50 +00:00
Close #11022: TextIOWrapper doesn't call locale.setlocale() anymore
open() and io.TextIOWrapper are now calling locale.getpreferredencoding(False) instead of locale.getpreferredencoding() in text mode if the encoding is not specified. Don't change temporary the locale encoding using locale.setlocale(), use the current locale encoding instead of the user preferred encoding. Explain also in open() documentation that locale.getpreferredencoding(False) is called if the encoding is not specified.
This commit is contained in:
parent
91c5a34613
commit
f86a5e8a93
8 changed files with 84 additions and 29 deletions
|
@ -112,8 +112,9 @@ PyDoc_STRVAR(open_doc,
|
|||
"'a' for appending (which on some Unix systems, means that all writes\n"
|
||||
"append to the end of the file regardless of the current seek position).\n"
|
||||
"In text mode, if encoding is not specified the encoding used is platform\n"
|
||||
"dependent. (For reading and writing raw bytes use binary mode and leave\n"
|
||||
"encoding unspecified.) The available modes are:\n"
|
||||
"dependent: locale.getpreferredencoding(False) is called to get the\n"
|
||||
"current locale encoding. (For reading and writing raw bytes use binary\n"
|
||||
"mode and leave encoding unspecified.) The available modes are:\n"
|
||||
"\n"
|
||||
"========= ===============================================================\n"
|
||||
"Character Meaning\n"
|
||||
|
|
|
@ -630,7 +630,7 @@ PyDoc_STRVAR(textiowrapper_doc,
|
|||
"Character and line based layer over a BufferedIOBase object, buffer.\n"
|
||||
"\n"
|
||||
"encoding gives the name of the encoding that the stream will be\n"
|
||||
"decoded or encoded with. It defaults to locale.getpreferredencoding.\n"
|
||||
"decoded or encoded with. It defaults to locale.getpreferredencoding(False).\n"
|
||||
"\n"
|
||||
"errors determines the strictness of encoding and decoding (see the\n"
|
||||
"codecs.register) and defaults to \"strict\".\n"
|
||||
|
@ -898,7 +898,7 @@ textiowrapper_init(textio *self, PyObject *args, PyObject *kwds)
|
|||
else {
|
||||
use_locale:
|
||||
self->encoding = _PyObject_CallMethodId(
|
||||
state->locale_module, &PyId_getpreferredencoding, NULL);
|
||||
state->locale_module, &PyId_getpreferredencoding, "O", Py_False);
|
||||
if (self->encoding == NULL) {
|
||||
catch_ImportError:
|
||||
/*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue