diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2015-05-30 14:48:54 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2015-05-30 14:48:54 (GMT) |
commit | e90982111ae1accc2a2ecaae94650a1d16a772ff (patch) | |
tree | 960c19c6de6a13c3aa3f1388ffe2898c112c61d0 /Objects/setobject.c | |
parent | f49c42324fb85596bcfaaba236ecd6e22138be72 (diff) | |
parent | ac5569b1fa483c50edca82bab1ab0a8a927ba86a (diff) | |
download | cpython-e90982111ae1accc2a2ecaae94650a1d16a772ff.zip cpython-e90982111ae1accc2a2ecaae94650a1d16a772ff.tar.gz cpython-e90982111ae1accc2a2ecaae94650a1d16a772ff.tar.bz2 |
Issue #24115: Update uses of PyObject_IsTrue(), PyObject_Not(),
PyObject_IsInstance(), PyObject_RichCompareBool() and _PyDict_Contains()
to check for and handle errors correctly.
Diffstat (limited to 'Objects/setobject.c')
-rw-r--r-- | Objects/setobject.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/Objects/setobject.c b/Objects/setobject.c index e1aa417..707ab95 100644 --- a/Objects/setobject.c +++ b/Objects/setobject.c @@ -1582,9 +1582,15 @@ set_difference(PySetObject *so, PyObject *other) if (PyDict_CheckExact(other)) { while (set_next(so, &pos, &entry)) { setentry entrycopy; + int rv; entrycopy.hash = entry->hash; entrycopy.key = entry->key; - if (!_PyDict_Contains(other, entry->key, entry->hash)) { + rv = _PyDict_Contains(other, entry->key, entry->hash); + if (rv < 0) { + Py_DECREF(result); + return NULL; + } + if (!rv) { if (set_add_entry((PySetObject *)result, &entrycopy)) { Py_DECREF(result); return NULL; @@ -1820,7 +1826,8 @@ PyDoc_STRVAR(issuperset_doc, "Report whether this set contains another set."); static PyObject * set_richcompare(PySetObject *v, PyObject *w, int op) { - PyObject *r1, *r2; + PyObject *r1; + int r2; if(!PyAnySet_Check(w)) Py_RETURN_NOTIMPLEMENTED; @@ -1838,9 +1845,11 @@ set_richcompare(PySetObject *v, PyObject *w, int op) r1 = set_richcompare(v, w, Py_EQ); if (r1 == NULL) return NULL; - r2 = PyBool_FromLong(PyObject_Not(r1)); + r2 = PyObject_IsTrue(r1); Py_DECREF(r1); - return r2; + if (r2 < 0) + return NULL; + return PyBool_FromLong(!r2); case Py_LE: return set_issubset(v, w); case Py_GE: |