summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAmaury Forgeot d'Arc <amauryfa@gmail.com>2009-06-01 21:28:37 (GMT)
committerAmaury Forgeot d'Arc <amauryfa@gmail.com>2009-06-01 21:28:37 (GMT)
commit24e581f7b2dbb700705c7b11c3982167ac68d4cb (patch)
tree8cc36814d81f3ad143bac22bb311ce49434995b7
parent1172999627c912b57ace149183de4a313edc74d2 (diff)
downloadcpython-24e581f7b2dbb700705c7b11c3982167ac68d4cb.zip
cpython-24e581f7b2dbb700705c7b11c3982167ac68d4cb.tar.gz
cpython-24e581f7b2dbb700705c7b11c3982167ac68d4cb.tar.bz2
Merged revisions 73114 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r73114 | amaury.forgeotdarc | 2009-06-01 22:53:18 +0200 (lun., 01 juin 2009) | 3 lines #4547: When debugging a very large function, it was not always possible to update the lineno attribute of the current frame. ........
-rw-r--r--Lib/test/test_trace.py17
-rw-r--r--Misc/NEWS3
-rw-r--r--Objects/frameobject.c4
3 files changed, 22 insertions, 2 deletions
diff --git a/Lib/test/test_trace.py b/Lib/test/test_trace.py
index ecb588c..43134e9 100644
--- a/Lib/test/test_trace.py
+++ b/Lib/test/test_trace.py
@@ -741,6 +741,23 @@ class JumpTestCase(unittest.TestCase):
def test_19_no_jump_without_trace_function(self):
no_jump_without_trace_function()
+ def test_20_large_function(self):
+ d = {}
+ exec("""def f(output): # line 0
+ x = 0 # line 1
+ y = 1 # line 2
+ ''' # line 3
+ %s # lines 4-1004
+ ''' # line 1005
+ x += 1 # line 1006
+ output.append(x) # line 1007
+ return""" % ('\n' * 1000,), d)
+ f = d['f']
+
+ f.jump = (2, 1007)
+ f.output = [0]
+ self.run_test(f)
+
def test_jump_to_firstlineno(self):
# This tests that PDB can jump back to the first line in a
# file. See issue #1689458. It can only be triggered in a
diff --git a/Misc/NEWS b/Misc/NEWS
index 570caea..6c39463 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -12,6 +12,9 @@ What's New in Python 3.1 Release Candidate 2?
Core and Builtins
-----------------
+- Issue #4547: When debugging a very large function, it was not always
+ possible to update the lineno attribute of the current frame.
+
- Issue #5330: C functions called with keyword arguments were not reported by
the various profiling modules (profile, cProfile). Patch by Hagen Fürstenau.
diff --git a/Objects/frameobject.c b/Objects/frameobject.c
index 8bb0f9c..a494992 100644
--- a/Objects/frameobject.c
+++ b/Objects/frameobject.c
@@ -69,7 +69,7 @@ frame_setlineno(PyFrameObject *f, PyObject* p_new_lineno)
int new_iblock = 0; /* The new value of f_iblock */
unsigned char *code = NULL; /* The bytecode for the frame... */
Py_ssize_t code_len = 0; /* ...and its length */
- char *lnotab = NULL; /* Iterating over co_lnotab */
+ unsigned char *lnotab = NULL; /* Iterating over co_lnotab */
Py_ssize_t lnotab_len = 0; /* (ditto) */
int offset = 0; /* (ditto) */
int line = 0; /* (ditto) */
@@ -131,7 +131,7 @@ frame_setlineno(PyFrameObject *f, PyObject* p_new_lineno)
/* Find the bytecode offset for the start of the given
* line, or the first code-owning line after it. */
PyBytes_AsStringAndSize(f->f_code->co_lnotab,
- &lnotab, &lnotab_len);
+ &(char*)lnotab, &lnotab_len);
addr = 0;
line = f->f_code->co_firstlineno;
new_lasti = -1;