From 0f1fd3e8bbfc8a4d9484a62efbe7952a0602be31 Mon Sep 17 00:00:00 2001 From: anatoly techtonik Date: Sun, 3 Feb 2013 20:01:13 +0300 Subject: Make Debug.caller_stack() return full stack. Previously it required to specify all needed levels as parameters, which is not practical. Now it return list of filename:line(function) strings starting from the root one. --- src/engine/SCons/Debug.py | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/src/engine/SCons/Debug.py b/src/engine/SCons/Debug.py index 85c0ec8..1c0c638 100644 --- a/src/engine/SCons/Debug.py +++ b/src/engine/SCons/Debug.py @@ -109,14 +109,15 @@ else: return res[4] # returns caller's stack -def caller_stack(*backlist): +def caller_stack(): import traceback - if not backlist: - backlist = [0] + tb = traceback.extract_stack() + # strip itself and the caller from the output + tb = tb[:-2] result = [] - for back in backlist: - tb = traceback.extract_stack(limit=3+back) - key = tb[0][:3] + for back in tb: + # (filename, line number, function name, text) + key = back[:3] result.append('%s:%d(%s)' % func_shorten(key)) return result -- cgit v0.12