[ python-Bugs-954364 ] 2.3 inspect.getframeinfo wrong tb line numbers

SourceForge.net noreply at sourceforge.net
Sat Jun 5 09:20:11 EDT 2004


Bugs item #954364, was opened at 2004-05-15 04:41
Message generated for change (Comment added) made by akuchling
You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=954364&group_id=5470

Category: Python Library
Group: Python 2.3
Status: Open
Resolution: None
Priority: 5
Submitted By: Robin Becker (rgbecker)
Assigned to: Nobody/Anonymous (nobody)
Summary: 2.3 inspect.getframeinfo wrong tb line numbers

Initial Comment:
inspect.getframeinfo always uses f_lineno even when
passed a tb. In practice it is not always true that

tb.tb_frame.f_lineno==tb.tb_lineno

so user functions like inspect.getinnerframes (and
hence cgitb) will get wrong information back sometimes.

I fixed this using the attached patch.

This script illustrates via cgitb.
############
def raise_an_error():
    a = 3
    b = 4
    c = 0
    try:
        a = a/c
    except:
        import sys, cgitb, traceback, inspect
        tbt,tbv,tb = sys.exc_info()
        print
'traceback\n',''.join(traceback.format_exception(tbt,tbv,tb))
        print '\n\ncgitb\n',cgitb.text((tbt,tbv,tb),1)

raise_an_error()
############





----------------------------------------------------------------------

>Comment By: A.M. Kuchling (akuchling)
Date: 2004-06-05 09:20

Message:
Logged In: YES 
user_id=11375

In the test program, the exception is raised at line 3, but the .trace() call 
says it was at line 5.


----------------------------------------------------------------------

Comment By: Robin Becker (rgbecker)
Date: 2004-06-05 08:44

Message:
Logged In: YES 
user_id=6946

python-2.4a0-954364.patch affects inspect.py,
test_inspect.py fixes this for me in 2.4a0 and 2.3.3, but
the semantics of inspect.trace changed so that
test_inspect.py must alter. If inspect.trace() should always
return something starting at the call of inspect.trace then
this patch is *WRONG*

----------------------------------------------------------------------

Comment By: Robin Becker (rgbecker)
Date: 2004-06-05 06:30

Message:
Logged In: YES 
user_id=6946

Whoops tabs and all that the above script should look like
#####start
def raise_an_error():
    a = 3
    b = 4
    c = 0
    try:
        a = a/c
    except:
        import sys, cgitb, traceback, inspect
        tbt,tbv,tb = sys.exc_info()
        print 'traceback\n',''.join(traceback.format_exception(tbt,tbv,tb))
        print '\n\ncgitb\n',cgitb.text((tbt,tbv,tb),1)

raise_an_error()
#####finish


The same problem occurs with inspect.trace. this code
#####start
import inspect
try:
    raise ValueError
except:
    print inspect.trace()
#####finish produces
[(<frame object at 0x007BFC60>, 'C:\tmp\ttt.py', 5, '?',
['    print inspect.trace()\n'], 0)]

ie the returned trace doesn't reflect the current traceback,
but rather the current frame location. This is also fixed by
the same patch. Still present in 2.4a0. This is a semantic
issue. The current test_inspect.py insists that the above
behaviour is correct so it will also need modifying if the
fix goes in.

----------------------------------------------------------------------

You can respond by visiting: 
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=954364&group_id=5470



More information about the Python-bugs-list mailing list