diff options
| author | Amaury Forgeot d'Arc <amauryfa@gmail.com> | 2009-06-01 21:28:37 +0000 | 
|---|---|---|
| committer | Amaury Forgeot d'Arc <amauryfa@gmail.com> | 2009-06-01 21:28:37 +0000 | 
| commit | 24e581f7b2dbb700705c7b11c3982167ac68d4cb (patch) | |
| tree | 8cc36814d81f3ad143bac22bb311ce49434995b7 | |
| parent | 1172999627c912b57ace149183de4a313edc74d2 (diff) | |
| download | cpython-git-24e581f7b2dbb700705c7b11c3982167ac68d4cb.tar.gz | |
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.py | 17 | ||||
| -rw-r--r-- | Misc/NEWS | 3 | ||||
| -rw-r--r-- | Objects/frameobject.c | 4 | 
3 files changed, 22 insertions, 2 deletions
| diff --git a/Lib/test/test_trace.py b/Lib/test/test_trace.py index ecb588c262..43134e98bd 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 @@ -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 8bb0f9c627..a49499286c 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; | 
