mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
Issue #16808: inspect.stack() now returns a named tuple instead of a tuple.
Patch by Daniel Shahaf.
This commit is contained in:
parent
1fa36268cf
commit
cdcafb78b2
4 changed files with 25 additions and 4 deletions
|
@ -1312,6 +1312,8 @@ def getlineno(frame):
|
|||
# FrameType.f_lineno is now a descriptor that grovels co_lnotab
|
||||
return frame.f_lineno
|
||||
|
||||
FrameInfo = namedtuple('FrameInfo', ('frame',) + Traceback._fields)
|
||||
|
||||
def getouterframes(frame, context=1):
|
||||
"""Get a list of records for a frame and all higher (calling) frames.
|
||||
|
||||
|
@ -1319,7 +1321,8 @@ def getouterframes(frame, context=1):
|
|||
name, a list of lines of context, and index within the context."""
|
||||
framelist = []
|
||||
while frame:
|
||||
framelist.append((frame,) + getframeinfo(frame, context))
|
||||
frameinfo = (frame,) + getframeinfo(frame, context)
|
||||
framelist.append(FrameInfo(*frameinfo))
|
||||
frame = frame.f_back
|
||||
return framelist
|
||||
|
||||
|
@ -1330,7 +1333,8 @@ def getinnerframes(tb, context=1):
|
|||
name, a list of lines of context, and index within the context."""
|
||||
framelist = []
|
||||
while tb:
|
||||
framelist.append((tb.tb_frame,) + getframeinfo(tb, context))
|
||||
frameinfo = (tb.tb_frame,) + getframeinfo(tb, context)
|
||||
framelist.append(FrameInfo(*frameinfo))
|
||||
tb = tb.tb_next
|
||||
return framelist
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue