Commit fb4d6ecd authored by Michael W. Hudson's avatar Michael W. Hudson

Fix for the recursion_level bug Armin Rigo reported in sf

patch #617312, both on the trunk and the 22-maint branch.

Also added a test case, and ported the test_trace I wrote for HEAD
to 2.2.2 (with all those horrible extra 'line' events ;-).
parent 3c6d6f2f
......@@ -177,8 +177,28 @@ class TraceTestCase(unittest.TestCase):
def test_9_settrace_and_raise(self):
self.run_test2(settrace_and_raise)
class RaisingTraceFuncTestCase(unittest.TestCase):
def test_it(self):
def tr(frame, event, arg):
raise ValueError # just something that isn't RuntimeError
def f():
return 1
try:
for i in xrange(sys.getrecursionlimit() + 1):
sys.settrace(tr)
try:
f()
except ValueError:
pass
else:
self.fail("exception not thrown!")
except RuntimeError:
self.fail("recursion counter not reset")
def test_main():
test_support.run_unittest(TraceTestCase)
test_support.run_unittest(RaisingTraceFuncTestCase)
if __name__ == "__main__":
test_main()
......@@ -636,6 +636,8 @@ eval_frame(PyFrameObject *f)
if (call_trace(tstate->c_tracefunc, tstate->c_traceobj,
f, PyTrace_CALL, Py_None)) {
/* Trace function raised an error */
--tstate->recursion_depth;
tstate->frame = f->f_back;
return NULL;
}
}
......@@ -646,6 +648,8 @@ eval_frame(PyFrameObject *f)
tstate->c_profileobj,
f, PyTrace_CALL, Py_None)) {
/* Profile function raised an error */
--tstate->recursion_depth;
tstate->frame = f->f_back;
return NULL;
}
}
......
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