Commit 3de58698 authored by Victor Stinner's avatar Victor Stinner

Issue #18408: PyObject_Call() now fails with an assertion error in debug mode

if the function called failed whereas no exception was raised, to detect bugs
earlier.
parent 33283ba3
......@@ -2104,10 +2104,16 @@ PyObject_Call(PyObject *func, PyObject *arg, PyObject *kw)
return NULL;
result = (*call)(func, arg, kw);
Py_LeaveRecursiveCall();
if (result == NULL && !PyErr_Occurred())
#ifdef NDEBUG
if (result == NULL && !PyErr_Occurred()) {
PyErr_SetString(
PyExc_SystemError,
"NULL result without error in PyObject_Call");
}
#else
if (result == NULL)
assert(PyErr_Occurred());
#endif
return result;
}
PyErr_Format(PyExc_TypeError, "'%.200s' object is not callable",
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment