diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2015-12-27 13:41:34 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2015-12-27 13:41:34 (GMT) |
commit | 191321d11bc7e064e1a07830a43fa600de310e1b (patch) | |
tree | 083b269838ac1e7dbea54ead1a4b79e99dbf4891 /Python | |
parent | 4a1e70fc31d224786a32f950edaf73c8ea9c194d (diff) | |
download | cpython-191321d11bc7e064e1a07830a43fa600de310e1b.zip cpython-191321d11bc7e064e1a07830a43fa600de310e1b.tar.gz cpython-191321d11bc7e064e1a07830a43fa600de310e1b.tar.bz2 |
Issue #20440: More use of Py_SETREF.
This patch is manually crafted and contains changes that couldn't be handled
automatically.
Diffstat (limited to 'Python')
-rw-r--r-- | Python/errors.c | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/Python/errors.c b/Python/errors.c index aed2bdc..7b67566 100644 --- a/Python/errors.c +++ b/Python/errors.c @@ -315,14 +315,11 @@ finally: tstate = PyThreadState_GET(); if (++tstate->recursion_depth > Py_GetRecursionLimit()) { --tstate->recursion_depth; - /* throw away the old exception... */ - Py_DECREF(*exc); - Py_DECREF(*val); - /* ... and use the recursion error instead */ - *exc = PyExc_RecursionError; - *val = PyExc_RecursionErrorInst; - Py_INCREF(*exc); - Py_INCREF(*val); + /* throw away the old exception and use the recursion error instead */ + Py_INCREF(PyExc_RecursionError); + Py_SETREF(*exc, PyExc_RecursionError); + Py_INCREF(PyExc_RecursionErrorInst); + Py_SETREF(*val, PyExc_RecursionErrorInst); /* just keeping the old traceback */ return; } |