Commit 64a263a1 authored by Serhiy Storchaka's avatar Serhiy Storchaka

Issue #20041: Fixed TypeError when frame.f_trace is set to None.

Patch by Xavier de Gaye.
parent 89beb270
...@@ -388,6 +388,15 @@ class TraceTestCase(unittest.TestCase): ...@@ -388,6 +388,15 @@ class TraceTestCase(unittest.TestCase):
(257, 'line'), (257, 'line'),
(257, 'return')]) (257, 'return')])
def test_17_none_f_trace(self):
# Issue 20041: fix TypeError when f_trace is set to None.
def func():
sys._getframe().f_trace = None
lineno = 2
self.run_and_compare(func,
[(0, 'call'),
(1, 'line')])
class RaisingTraceFuncTestCase(unittest.TestCase): class RaisingTraceFuncTestCase(unittest.TestCase):
def setUp(self): def setUp(self):
......
...@@ -10,6 +10,9 @@ Release date: tba ...@@ -10,6 +10,9 @@ Release date: tba
Core and Builtins Core and Builtins
----------------- -----------------
- Issue #20041: Fixed TypeError when frame.f_trace is set to None.
Patch by Xavier de Gaye.
- Issue #26168: Fixed possible refleaks in failing Py_BuildValue() with the "N" - Issue #26168: Fixed possible refleaks in failing Py_BuildValue() with the "N"
format unit. format unit.
......
...@@ -349,15 +349,13 @@ frame_gettrace(PyFrameObject *f, void *closure) ...@@ -349,15 +349,13 @@ frame_gettrace(PyFrameObject *f, void *closure)
static int static int
frame_settrace(PyFrameObject *f, PyObject* v, void *closure) frame_settrace(PyFrameObject *f, PyObject* v, void *closure)
{ {
PyObject* old_value;
/* We rely on f_lineno being accurate when f_trace is set. */ /* We rely on f_lineno being accurate when f_trace is set. */
f->f_lineno = PyFrame_GetLineNumber(f); f->f_lineno = PyFrame_GetLineNumber(f);
old_value = f->f_trace; if (v == Py_None)
v = NULL;
Py_XINCREF(v); Py_XINCREF(v);
f->f_trace = v; Py_XSETREF(f->f_trace, v);
Py_XDECREF(old_value);
return 0; return 0;
} }
......
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