mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
bpo-47000: Make io.text_encoding()
respects UTF-8 mode (GH-32003)
Co-authored-by: Eric Snow <ericsnowcurrently@gmail.com>
This commit is contained in:
parent
6db2db91b9
commit
4216dce04b
10 changed files with 52 additions and 17 deletions
|
@ -457,8 +457,9 @@ _io.text_encoding
|
|||
|
||||
A helper function to choose the text encoding.
|
||||
|
||||
When encoding is not None, just return it.
|
||||
Otherwise, return the default text encoding (i.e. "locale").
|
||||
When encoding is not None, this function returns it.
|
||||
Otherwise, this function returns the default text encoding
|
||||
(i.e. "locale" or "utf-8" depends on UTF-8 mode).
|
||||
|
||||
This function emits an EncodingWarning if encoding is None and
|
||||
sys.flags.warn_default_encoding is true.
|
||||
|
@ -469,7 +470,7 @@ However, please consider using encoding="utf-8" for new APIs.
|
|||
|
||||
static PyObject *
|
||||
_io_text_encoding_impl(PyObject *module, PyObject *encoding, int stacklevel)
|
||||
/*[clinic end generated code: output=91b2cfea6934cc0c input=bf70231213e2a7b4]*/
|
||||
/*[clinic end generated code: output=91b2cfea6934cc0c input=4999aa8b3d90f3d4]*/
|
||||
{
|
||||
if (encoding == NULL || encoding == Py_None) {
|
||||
PyInterpreterState *interp = _PyInterpreterState_GET();
|
||||
|
@ -479,7 +480,14 @@ _io_text_encoding_impl(PyObject *module, PyObject *encoding, int stacklevel)
|
|||
return NULL;
|
||||
}
|
||||
}
|
||||
return &_Py_ID(locale);
|
||||
const PyPreConfig *preconfig = &_PyRuntime.preconfig;
|
||||
if (preconfig->utf8_mode) {
|
||||
_Py_DECLARE_STR(utf_8, "utf-8");
|
||||
encoding = &_Py_STR(utf_8);
|
||||
}
|
||||
else {
|
||||
encoding = &_Py_ID(locale);
|
||||
}
|
||||
}
|
||||
Py_INCREF(encoding);
|
||||
return encoding;
|
||||
|
|
7
Modules/_io/clinic/_iomodule.c.h
generated
7
Modules/_io/clinic/_iomodule.c.h
generated
|
@ -273,8 +273,9 @@ PyDoc_STRVAR(_io_text_encoding__doc__,
|
|||
"\n"
|
||||
"A helper function to choose the text encoding.\n"
|
||||
"\n"
|
||||
"When encoding is not None, just return it.\n"
|
||||
"Otherwise, return the default text encoding (i.e. \"locale\").\n"
|
||||
"When encoding is not None, this function returns it.\n"
|
||||
"Otherwise, this function returns the default text encoding\n"
|
||||
"(i.e. \"locale\" or \"utf-8\" depends on UTF-8 mode).\n"
|
||||
"\n"
|
||||
"This function emits an EncodingWarning if encoding is None and\n"
|
||||
"sys.flags.warn_default_encoding is true.\n"
|
||||
|
@ -354,4 +355,4 @@ _io_open_code(PyObject *module, PyObject *const *args, Py_ssize_t nargs, PyObjec
|
|||
exit:
|
||||
return return_value;
|
||||
}
|
||||
/*[clinic end generated code: output=6ea315343f6a94ba input=a9049054013a1b77]*/
|
||||
/*[clinic end generated code: output=1a7fd7755c9a9609 input=a9049054013a1b77]*/
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue