summaryrefslogtreecommitdiff
path: root/lab/run_trace.py
diff options
context:
space:
mode:
authorNed Batchelder <ned@nedbatchelder.com>2015-04-20 07:20:44 -0400
committerNed Batchelder <ned@nedbatchelder.com>2015-04-20 07:20:44 -0400
commitdd20fcfbcce90933099b10629424dc0cccafc5db (patch)
treee89c5a0f796fba1cf962f5daebddab43dddae3ed /lab/run_trace.py
parent35441323f82adfd68703fa516e42286d70ea3f86 (diff)
downloadpython-coveragepy-git-dd20fcfbcce90933099b10629424dc0cccafc5db.tar.gz
Make this lab program more useful for examining how trace functions work.
--HG-- rename : lab/trace_sample.py => lab/run_trace.py
Diffstat (limited to 'lab/run_trace.py')
-rw-r--r--lab/run_trace.py32
1 files changed, 32 insertions, 0 deletions
diff --git a/lab/run_trace.py b/lab/run_trace.py
new file mode 100644
index 00000000..3822a804
--- /dev/null
+++ b/lab/run_trace.py
@@ -0,0 +1,32 @@
+"""Run a simple trace function on a file of Python code."""
+
+import os, sys
+
+nest = 0
+
+def trace(frame, event, arg):
+ global nest
+
+ if nest is None:
+ # This can happen when Python is shutting down.
+ return None
+
+ print "%s%s %s %d @%d" % (
+ " " * nest,
+ event,
+ os.path.basename(frame.f_code.co_filename),
+ frame.f_lineno,
+ frame.f_lasti,
+ )
+
+ if event == 'call':
+ nest += 1
+ if event == 'return':
+ nest -= 1
+
+ return trace
+
+the_program = sys.argv[1]
+
+sys.settrace(trace)
+execfile(the_program)