mirror of
https://github.com/python/cpython.git
synced 2025-11-02 03:01:58 +00:00
Issue #29190: Fixed possible errors in comparing strings in the pickle module.
This commit is contained in:
commit
f0f35a6720
1 changed files with 6 additions and 12 deletions
|
|
@ -1560,9 +1560,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;
|
||||||
|
|
||||||
|
|
@ -1573,12 +1573,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);
|
||||||
|
|
@ -3552,12 +3547,11 @@ save_reduce(PicklerObject *self, PyObject *args, PyObject *obj)
|
||||||
}
|
}
|
||||||
else if (PyUnicode_Check(name)) {
|
else if (PyUnicode_Check(name)) {
|
||||||
_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…
Add table
Add a link
Reference in a new issue