[Python-checkins] r73120 - in python/branches/release30-maint: Lib/test/test_trace.py Misc/NEWS Objects/frameobject.c

amaury.forgeotdarc python-checkins at python.org
Tue Jun 2 00:19:47 CEST 2009


Author: amaury.forgeotdarc
Date: Tue Jun  2 00:19:47 2009
New Revision: 73120

Log:
Merged revisions 73117 via svnmerge from 
svn+ssh://pythondev@svn.python.org/python/branches/py3k

................
  r73117 | amaury.forgeotdarc | 2009-06-01 23:28:37 +0200 (lun., 01 juin 2009) | 10 lines
  
  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.
  ........
................


Modified:
   python/branches/release30-maint/   (props changed)
   python/branches/release30-maint/Lib/test/test_trace.py
   python/branches/release30-maint/Misc/NEWS
   python/branches/release30-maint/Objects/frameobject.c

Modified: python/branches/release30-maint/Lib/test/test_trace.py
==============================================================================
--- python/branches/release30-maint/Lib/test/test_trace.py	(original)
+++ python/branches/release30-maint/Lib/test/test_trace.py	Tue Jun  2 00:19:47 2009
@@ -741,6 +741,23 @@
     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_main():
     support.run_unittest(
         TraceTestCase,

Modified: python/branches/release30-maint/Misc/NEWS
==============================================================================
--- python/branches/release30-maint/Misc/NEWS	(original)
+++ python/branches/release30-maint/Misc/NEWS	Tue Jun  2 00:19:47 2009
@@ -12,6 +12,9 @@
 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 #6089: Fixed str.format with certain invalid field specifiers
   that would raise SystemError.
 

Modified: python/branches/release30-maint/Objects/frameobject.c
==============================================================================
--- python/branches/release30-maint/Objects/frameobject.c	(original)
+++ python/branches/release30-maint/Objects/frameobject.c	Tue Jun  2 00:19:47 2009
@@ -69,7 +69,7 @@
 	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) */
@@ -125,7 +125,8 @@
 
 	/* 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);
+	PyBytes_AsStringAndSize(f->f_code->co_lnotab,
+	                        &(char*)lnotab, &lnotab_len);
 	addr = 0;
 	line = f->f_code->co_firstlineno;
 	new_lasti = -1;


More information about the Python-checkins mailing list