summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2017-01-09 08:10:07 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2017-01-09 08:10:07 (GMT)
commit32999ab48a143b416dc0dbcc3877a7c218042c2b (patch)
tree8dabe2df5e6774ca10f2418c0bfa99183c7f4670
parent04c15d5bdc1960be67b4d93f846141e6451a0c6c (diff)
parentf0f35a6720a3e3aa8298ad5ff1319589968a2215 (diff)
downloadcpython-32999ab48a143b416dc0dbcc3877a7c218042c2b.zip
cpython-32999ab48a143b416dc0dbcc3877a7c218042c2b.tar.gz
cpython-32999ab48a143b416dc0dbcc3877a7c218042c2b.tar.bz2
Issue #29190: Fixed possible errors in comparing strings in the pickle module.
-rw-r--r--Modules/_pickle.c18
1 files changed, 6 insertions, 12 deletions
diff --git a/Modules/_pickle.c b/Modules/_pickle.c
index b1e1d49..19f94dc 100644
--- a/Modules/_pickle.c
+++ b/Modules/_pickle.c
@@ -1560,9 +1560,9 @@ memo_put(PicklerObject *self, PyObject *obj)
}
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_locals, "<locals>");
PyObject *dotted_path;
Py_ssize_t i, n;
@@ -1573,12 +1573,7 @@ get_dotted_path(PyObject *obj, PyObject *name) {
assert(n >= 1);
for (i = 0; i < n; i++) {
PyObject *subpath = PyList_GET_ITEM(dotted_path, i);
- PyObject *result = PyUnicode_RichCompare(
- subpath, _PyUnicode_FromId(&PyId_locals), Py_EQ);
- int is_equal = (result == Py_True);
- assert(PyBool_Check(result));
- Py_DECREF(result);
- if (is_equal) {
+ if (_PyUnicode_EqualToASCIIString(subpath, "<locals>")) {
if (obj == NULL)
PyErr_Format(PyExc_AttributeError,
"Can't pickle local object %R", name);
@@ -3549,12 +3544,11 @@ save_reduce(PicklerObject *self, PyObject *args, PyObject *obj)
}
else if (PyUnicode_Check(name)) {
_Py_IDENTIFIER(__newobj_ex__);
- use_newobj_ex = PyUnicode_Compare(
- name, _PyUnicode_FromId(&PyId___newobj_ex__)) == 0;
+ use_newobj_ex = _PyUnicode_EqualToASCIIId(
+ name, &PyId___newobj_ex__);
if (!use_newobj_ex) {
_Py_IDENTIFIER(__newobj__);
- use_newobj = PyUnicode_Compare(
- name, _PyUnicode_FromId(&PyId___newobj__)) == 0;
+ use_newobj = _PyUnicode_EqualToASCIIId(name, &PyId___newobj__);
}
}
Py_XDECREF(name);