我已经开始尝试为我的一些C数据结构构建gdb漂亮的打印机,但 documentation非常薄.
因此,我需要猜测如何做事情,而且我的漂亮打印机经常崩溃一个无用的python异常,没有指出实际问题在哪里.
有没有什么好方法可以调试漂亮的打印机?通过在代码中插入对pydb的显式调用,我在其他python程序中取得了成功:
import pydb
pydb.debugger()
但是在gdb中运行python时似乎没有用 – 它只是运行调试器调用而不停止或说或做任何事情.
最佳答案 您可以在gdb中运行pdb(其中一个python调试器).以下是带有简单示例的gdb会话的摘录:
(gdb) print (ObjectSignature *) 0x7f71e4018000
$1 = (ObjectSignature *) 0x7f71e4018000
(gdb) python import pdb
(gdb) python pdb.run('gdb.execute("print $1[0]")')
> <string>(1)<module>()
(Pdb) from svtprinters.printers import ObjectSignaturePrinter
(Pdb) b ObjectSignaturePrinter.to_string
Breakpoint 1 at /svtfs/svtprinters/printers.py:195
(Pdb) c
$2 = > /svtfs/svtprinters/printers.py(196)to_string()
-> sizetypestr = 'invalid'
(Pdb) n
> /svtfs/svtprinters/printers.py(197)to_string()
-> sizetypeidx = int(self.val['mSizeType'])
(Pdb) self.val['mSizeType']
<gdb.Value object at 0x7effc90ff430>
(Pdb) int(self.val['mSizeType'])
3
(Pdb) n
> /svtfs/svtprinters/printers.py(199)to_string()
-> if sizetypeidx < len(self.sizetypes):
(Pdb) self.sizetypes
['unknown', 'meta_1K', 'data_4K', 'data_8K', 'data_16K', 'data_32K', 'data_64K']
(Pdb) n
> /svtfs/svtprinters/printers.py(200)to_string()
-> sizetypestr = self.sizetypes[sizetypeidx]
(Pdb)
> /svtfs/svtprinters/printers.py(202)to_string()
-> return (20*"%02x"+" %s") % tuple([self.val['mValue'][i] for i in range(20)]+[sizetypestr])
(Pdb) sizetypestr
'data_8K'
(Pdb) c
98d6687a2ea63a134901f0df140b13112e64bfb7 data_8K
(gdb)
在此示例中,ObjectSignaturePrinter是一个通过gdb.pretty_printers与$1中的ObjectSignature类型相关联的类.第二个打印命令的输出被分割;在达到漂亮的打印机断点之前打印$2 =,并在pdb continue命令之后显示其余输出.
这种方法的变体很可能适用于其他python调试器.