diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2013-07-08 20:27:42 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2013-07-08 20:27:42 (GMT) |
commit | 0ff0f54dd498170d5698132d24deeeaaab9bf5df (patch) | |
tree | 71596aee9ad338c70dae4198c6e3a9e4e8069016 /Python | |
parent | 9812af8e727ee38f6526d377d84fb7f4507e23bc (diff) | |
download | cpython-0ff0f54dd498170d5698132d24deeeaaab9bf5df.zip cpython-0ff0f54dd498170d5698132d24deeeaaab9bf5df.tar.gz cpython-0ff0f54dd498170d5698132d24deeeaaab9bf5df.tar.bz2 |
Issue #18408: Fix call_function() of ceval.c to handle PyTuple_New() failure
(in load_args()), ex: MemoryError.
Diffstat (limited to 'Python')
-rw-r--r-- | Python/ceval.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/Python/ceval.c b/Python/ceval.c index e184ef6..82e85ca 100644 --- a/Python/ceval.c +++ b/Python/ceval.c @@ -4171,10 +4171,15 @@ call_function(PyObject ***pp_stack, int oparg else { PyObject *callargs; callargs = load_args(pp_stack, na); - READ_TIMESTAMP(*pintr0); - C_TRACE(x, PyCFunction_Call(func,callargs,NULL)); - READ_TIMESTAMP(*pintr1); - Py_XDECREF(callargs); + if (callargs != NULL) { + READ_TIMESTAMP(*pintr0); + C_TRACE(x, PyCFunction_Call(func,callargs,NULL)); + READ_TIMESTAMP(*pintr1); + Py_XDECREF(callargs); + } + else { + x = NULL; + } } } else { if (PyMethod_Check(func) && PyMethod_GET_SELF(func) != NULL) { |