Issue #29190: Fixed possible errors in comparing strings in the pickle module.
This commit is contained in:
parent
959ff7f1c6
commit
9937d90ee8
|
@ -1548,9 +1548,9 @@ memo_put(PicklerObject *self, PyObject *obj)
|
||||||
}
|
}
|
||||||
|
|
||||||
static PyObject *
|
static PyObject *
|
||||||
get_dotted_path(PyObject *obj, PyObject *name) {
|
get_dotted_path(PyObject *obj, PyObject *name)
|
||||||
|
{
|
||||||
_Py_static_string(PyId_dot, ".");
|
_Py_static_string(PyId_dot, ".");
|
||||||
_Py_static_string(PyId_locals, "<locals>");
|
|
||||||
PyObject *dotted_path;
|
PyObject *dotted_path;
|
||||||
Py_ssize_t i, n;
|
Py_ssize_t i, n;
|
||||||
|
|
||||||
|
@ -1561,12 +1561,7 @@ get_dotted_path(PyObject *obj, PyObject *name) {
|
||||||
assert(n >= 1);
|
assert(n >= 1);
|
||||||
for (i = 0; i < n; i++) {
|
for (i = 0; i < n; i++) {
|
||||||
PyObject *subpath = PyList_GET_ITEM(dotted_path, i);
|
PyObject *subpath = PyList_GET_ITEM(dotted_path, i);
|
||||||
PyObject *result = PyUnicode_RichCompare(
|
if (_PyUnicode_EqualToASCIIString(subpath, "<locals>")) {
|
||||||
subpath, _PyUnicode_FromId(&PyId_locals), Py_EQ);
|
|
||||||
int is_equal = (result == Py_True);
|
|
||||||
assert(PyBool_Check(result));
|
|
||||||
Py_DECREF(result);
|
|
||||||
if (is_equal) {
|
|
||||||
if (obj == NULL)
|
if (obj == NULL)
|
||||||
PyErr_Format(PyExc_AttributeError,
|
PyErr_Format(PyExc_AttributeError,
|
||||||
"Can't pickle local object %R", name);
|
"Can't pickle local object %R", name);
|
||||||
|
@ -3537,13 +3532,12 @@ save_reduce(PicklerObject *self, PyObject *args, PyObject *obj)
|
||||||
else if (PyUnicode_Check(name)) {
|
else if (PyUnicode_Check(name)) {
|
||||||
if (self->proto >= 4) {
|
if (self->proto >= 4) {
|
||||||
_Py_IDENTIFIER(__newobj_ex__);
|
_Py_IDENTIFIER(__newobj_ex__);
|
||||||
use_newobj_ex = PyUnicode_Compare(
|
use_newobj_ex = _PyUnicode_EqualToASCIIId(
|
||||||
name, _PyUnicode_FromId(&PyId___newobj_ex__)) == 0;
|
name, &PyId___newobj_ex__);
|
||||||
}
|
}
|
||||||
if (!use_newobj_ex) {
|
if (!use_newobj_ex) {
|
||||||
_Py_IDENTIFIER(__newobj__);
|
_Py_IDENTIFIER(__newobj__);
|
||||||
use_newobj = PyUnicode_Compare(
|
use_newobj = _PyUnicode_EqualToASCIIId(name, &PyId___newobj__);
|
||||||
name, _PyUnicode_FromId(&PyId___newobj__)) == 0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Py_XDECREF(name);
|
Py_XDECREF(name);
|
||||||
|
|
Loading…
Reference in New Issue