- Fixed bug when bp is set on same addr
[pygdb.git] / StatusWindow.py
1 #!/usr/bin/python
2 #shuber, 2008-06-04
3
4 __author__ = "shuber"
5
6
7 import gtk
8 import vte
9
10 import BreakpointsFrame
11 import WatchesFrame
12
13
14
15 class StatusWindow (gtk.Window):
16
17 def __init__(self, mainctrlwnd, debugger):
18
19 gtk.Window.__init__(self)
20 self.debugger = debugger
21
22 self.set_border_width(5)
23 self.set_title("Status")
24 self.set_default_size(400,600)
25 self.connect("destroy", lambda *w: gtk.main_quit())
26
27 vbox = gtk.VBox(False, 5)
28 self.add(vbox)
29
30 self.status = gtk.Label("Not Running")
31 vbox.pack_start(self.status, False, False)
32 vpaned = gtk.VPaned()
33 vbox.add(vpaned)
34
35 #Adding the frames
36 self.frames = []
37 self.frames += [WatchesFrame.WatchesFrame(debugger)]
38 self.frames += [BreakpointsFrame.BreakpointsFrame(debugger)]
39 vpaned.add1(self.frames[0])
40 vpaned.add2(self.frames[1])
41
42 #Register callback function for new positions
43 #and update the values
44 mainctrlwnd.newPosCbs += [self.updateValues]
45
46 self.show_all()
47
48
49 def applyConfiguration(self, conf):
50
51 while not self.debugger.isActive():
52 gtk.main_iteration()
53
54 for f in self.frames:
55 f.applyConfiguration(conf)
56
57
58 def fillConfiguration(self, conf):
59 for f in self.frames:
60 f.fillConfiguration(conf)
61
62
63 def updateValues(self, pos):
64
65 if pos == None:
66 self.status.set_text("Exited")
67 else:
68 file, lineno = pos
69 self.status.set_text("%s:%s" % (file, lineno))
70
71 for f in self.frames:
72 f.updateValues(pos)
73
74