summaryrefslogtreecommitdiffstats
path: root/Python/ceval.c
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2021-07-19 11:15:58 (GMT)
committerGitHub <noreply@github.com>2021-07-19 11:15:58 (GMT)
commit37bdd2221ce3607a81d5d7fafc4603d95ca3e8cb (patch)
tree3de484aad19145bca4dd50e30f70a9eeb5ea3a15 /Python/ceval.c
parentbce2847169e181ae894b323b9d5c31b0a3bec621 (diff)
downloadcpython-37bdd2221ce3607a81d5d7fafc4603d95ca3e8cb.zip
cpython-37bdd2221ce3607a81d5d7fafc4603d95ca3e8cb.tar.gz
cpython-37bdd2221ce3607a81d5d7fafc4603d95ca3e8cb.tar.bz2
bpo-44645: Check for interrupts on any potentially backwards edge (GH-27216) (GH-27235)
(cherry picked from commit d09c13417890427f829e3df297beb0e27133f8f4) Co-authored-by: Mark Shannon <mark@hotpy.org>
Diffstat (limited to 'Python/ceval.c')
-rw-r--r--Python/ceval.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/Python/ceval.c b/Python/ceval.c
index 6482c88..429ddb8 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -3759,14 +3759,17 @@ main_loop:
if (Py_IsFalse(cond)) {
Py_DECREF(cond);
JUMPTO(oparg);
+ CHECK_EVAL_BREAKER();
DISPATCH();
}
err = PyObject_IsTrue(cond);
Py_DECREF(cond);
if (err > 0)
;
- else if (err == 0)
+ else if (err == 0) {
JUMPTO(oparg);
+ CHECK_EVAL_BREAKER();
+ }
else
goto error;
DISPATCH();
@@ -3783,12 +3786,14 @@ main_loop:
if (Py_IsTrue(cond)) {
Py_DECREF(cond);
JUMPTO(oparg);
+ CHECK_EVAL_BREAKER();
DISPATCH();
}
err = PyObject_IsTrue(cond);
Py_DECREF(cond);
if (err > 0) {
JUMPTO(oparg);
+ CHECK_EVAL_BREAKER();
}
else if (err == 0)
;