diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2012-08-15 23:16:51 +0200 |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2012-08-15 23:16:51 +0200 |
commit | c5bef75c77af414c2f6c5901b6838d3071313bc7 (patch) | |
tree | ec54e539c09e4c9b6fc8963258fef4c6484e5573 /Python/bltinmodule.c | |
parent | 4ffe9a064022b973ab152d108b13c470af486a74 (diff) | |
download | cpython-git-c5bef75c77af414c2f6c5901b6838d3071313bc7.tar.gz |
Issue #15604: Update uses of PyObject_IsTrue() to check for and handle errors correctly.
Patch by Serhiy Storchaka.
Diffstat (limited to 'Python/bltinmodule.c')
-rw-r--r-- | Python/bltinmodule.c | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c index 3def0800aa..a07b78c8d9 100644 --- a/Python/bltinmodule.c +++ b/Python/bltinmodule.c @@ -313,7 +313,7 @@ builtin_filter(PyObject *self, PyObject *args) ok = PyObject_IsTrue(good); Py_DECREF(good); } - if (ok) { + if (ok > 0) { if (j < len) PyList_SET_ITEM(result, j, item); else { @@ -324,8 +324,11 @@ builtin_filter(PyObject *self, PyObject *args) } ++j; } - else + else { Py_DECREF(item); + if (ok < 0) + goto Fail_result_it; + } } @@ -2784,12 +2787,15 @@ filtertuple(PyObject *func, PyObject *tuple) } ok = PyObject_IsTrue(good); Py_DECREF(good); - if (ok) { + if (ok > 0) { if (PyTuple_SetItem(result, j++, item) < 0) goto Fail_1; } - else + else { Py_DECREF(item); + if (ok < 0) + goto Fail_1; + } } if (_PyTuple_Resize(&result, j) < 0) @@ -2851,7 +2857,7 @@ filterstring(PyObject *func, PyObject *strobj) ok = PyObject_IsTrue(good); Py_DECREF(good); } - if (ok) { + if (ok > 0) { Py_ssize_t reslen; if (!PyString_Check(item)) { PyErr_SetString(PyExc_TypeError, "can't filter str to str:" @@ -2917,6 +2923,8 @@ filterstring(PyObject *func, PyObject *strobj) } } Py_DECREF(item); + if (ok < 0) + goto Fail_1; } if (j < outlen) @@ -2977,7 +2985,7 @@ filterunicode(PyObject *func, PyObject *strobj) ok = PyObject_IsTrue(good); Py_DECREF(good); } - if (ok) { + if (ok > 0) { Py_ssize_t reslen; if (!PyUnicode_Check(item)) { PyErr_SetString(PyExc_TypeError, @@ -3032,6 +3040,8 @@ filterunicode(PyObject *func, PyObject *strobj) } } Py_DECREF(item); + if (ok < 0) + goto Fail_1; } if (j < outlen) |