blob: 4790adae54cfc78f82d4e1f084ade0d5a1cf94f9 [file] [log] [blame]
Barry Warsaw39e44d72001-01-23 16:25:19 +00001# -*- ksh -*-
2#
3# If you use the GNU debugger gdb to debug the Python C runtime, you
4# might find some of the following commands useful. Copy this to your
5# ~/.gdbinit file and it'll get loaded into gdb automatically when you
6# start it up. Then, at the gdb prompt you can do things like:
7#
8# (gdb) pyo apyobjectptr
9# <module 'foobar' (built-in)>
10# refcounts: 1
11# address : 84a7a2c
12# $1 = void
13# (gdb)
14
15# Prints a representation of the object to stderr, along with the
16# number of reference counts it current has and the hex address the
17# object is allocated at. The argument must be a PyObject*
18define pyo
Barry Warsawbbd89b62001-01-24 04:18:13 +000019print _PyObject_Dump($arg0)
Barry Warsaw39e44d72001-01-23 16:25:19 +000020end
21
22# Prints a representation of the object to stderr, along with the
23# number of reference counts it current has and the hex address the
24# object is allocated at. The argument must be a PyGC_Head*
25define pyg
Barry Warsawbbd89b62001-01-24 04:18:13 +000026print _PyGC_Dump($arg0)
Barry Warsaw39e44d72001-01-23 16:25:19 +000027end
Jeremy Hyltonf64ec0f2003-10-03 20:56:15 +000028
29# If you are in an eval_frame() function, calling pyframe with no
30# arguments will print the filename, function name, and line number.
31# It assumes that f is the name of the current frame.
32define pyframe
33x/s ((PyStringObject*)f->f_code->co_filename)->ob_sval
34x/s ((PyStringObject*)f->f_code->co_name)->ob_sval
35p f->f_lineno
36end
Skip Montanaro786ea6b2004-03-01 15:44:05 +000037
38# Here's a somewhat fragile way to print the entire Python stack from gdb.
39# It's fragile because the tests for the value of $pc depend on the layout
40# of specific functions in the C source code.
41
42# Explanation of while and if tests: We want to pop up the stack until we
43# land in Py_Main (this is probably an incorrect assumption in an embedded
44# interpreter, but the test can be extended by an interested party). If
45# Py_Main <= $pc <= Py_GetArgcArv is true $pc is in Py_Main(), so the while
46# tests succeeds as long as it's not true. In a similar fashion the if
47# statement tests to see if we are in eval_frame().
48
49define pystack
50 while $pc < Py_Main || $pc > Py_GetArgcArgv
51 if $pc > eval_frame && $pc < PyEval_EvalCodeEx
52 set $__fn = PyString_AsString(co->co_filename)
53 set $__n = PyString_AsString(co->co_name)
54 printf "%s (%d): %s\n", $__fn, f->f_lineno, $__n
55 end
56 up-silently 1
57 end
58 select-frame 0
59end