Kod poniżej wykorzystuje funkcje introspekcji Pythona do dodania dwóch nowych poleceń do modułu PDB 0 wystarczy umieścić daną funkcję i jej wywołanie w oddzielnym module i zaimportować ten moduł przed rozpoczęciem debugowania - powinieneś mieć "disp" Polecenia 'i' undisp 'dodają i wycofują zegarki do zmiennych.
Działa przez monkeypatching modułu pdb Pythona, który jest napisany czystym pythonem.
# -*- coding: utf-8 -*-
def patch_pdb():
import pdb
def wrap(func):
def new_postcmd(self, *args, **kw):
result = func(self, *args, **kw)
if hasattr(self, "curframe") and self.curframe and hasattr(self, "watch_list"):
for arg in self.watch_list:
try:
print >> self.stdout, "%s: %s"% (arg, self._getval(arg)) + ", ",
except:
pass
self.stdout.write("\n")
return result #func(self, *args, **kw)
return new_postcmd
pdb.Pdb.postcmd = wrap(pdb.Pdb.postcmd)
def do_disp(self, arg):
if not hasattr(self, "watch_list"):
self.watch_list = []
self.watch_list.append(arg)
pdb.Pdb.do_disp = do_disp
def do_undisp(self, arg):
if hasattr(self, "watch_list"):
try:
self.watch_list.remove(arg)
except:
pass
pdb.Pdb.do_undisp = do_undisp
patch_pdb()
if __name__ == "__main__":
# for testing
import pdb; pdb.set_trace()
a = 0
for i in range(10):
print i
a += 2
Niestety, mogłem tylko sprawić, aby wyświetlał stan zmiennych w miejscu, w którym poprzednio wykonywał ostatnie polecenie. (Próbowałem trochę, ale monkeypatching modułu bdb, który jest podstawą dla Pdb, również nie działa tak dobrze). Możesz spróbować zmienić metody w plikach pdb.Pdb, bdb.Bdb lub cmd.Cmd, które są dekorowane przez wrap
, aby znaleźć taki, który jest wywoływany po zmianie stanu debugowanego klatki.
może ipdb ma jakąś alternatywną funkcjonalność – bph
jako alternatywa, jeśli lubisz ładne UI, możesz użyć [ pudb] (https://pypi.python.org/pypi/pudb). –