mirror of
https://github.com/python/cpython.git
synced 2025-09-18 14:40:43 +00:00
Issue #15604: Update uses of PyObject_IsTrue() to check for and handle errors correctly.
Patch by Serhiy Storchaka.
This commit is contained in:
parent
4ffe9a0640
commit
c5bef75c77
11 changed files with 112 additions and 52 deletions
|
@ -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)
|
||||
|
|
|
@ -1043,7 +1043,10 @@ load_source_module(char *name, char *pathname, FILE *fp)
|
|||
name, pathname);
|
||||
if (cpathname) {
|
||||
PyObject *ro = PySys_GetObject("dont_write_bytecode");
|
||||
if (ro == NULL || !PyObject_IsTrue(ro))
|
||||
int b = (ro == NULL) ? 0 : PyObject_IsTrue(ro);
|
||||
if (b < 0)
|
||||
goto error_exit;
|
||||
if (!b)
|
||||
write_compiled_module(co, cpathname, &st);
|
||||
}
|
||||
}
|
||||
|
@ -2200,7 +2203,13 @@ import_module_level(char *name, PyObject *globals, PyObject *locals,
|
|||
}
|
||||
|
||||
if (fromlist != NULL) {
|
||||
if (fromlist == Py_None || !PyObject_IsTrue(fromlist))
|
||||
int b = (fromlist == Py_None) ? 0 : PyObject_IsTrue(fromlist);
|
||||
if (b < 0) {
|
||||
Py_DECREF(tail);
|
||||
Py_DECREF(head);
|
||||
goto error_exit;
|
||||
}
|
||||
if (!b)
|
||||
fromlist = NULL;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue