X-Git-Url: https://git.sthu.org/?a=blobdiff_plain;f=GdbTerminal.py;h=ff6dc6b37356133c8d526fbb1f02f9f0dd6c9d3a;hb=afd9117c8d1d5f614acc120f28c668655be20abf;hp=8600c90d0a94e4e7f1f1733f15a1bf70f8551727;hpb=0296b6d5afe20a15764842873917bf1d6aa34b77;p=pygdb.git diff --git a/GdbTerminal.py b/GdbTerminal.py old mode 100755 new mode 100644 index 8600c90..ff6dc6b --- a/GdbTerminal.py +++ b/GdbTerminal.py @@ -23,10 +23,6 @@ class GdbTerminal (DbgTerminal.DbgTerminal): def getArgv(self): return ["gdb", "--fullname", string.split(self.clientCmd)[0]] - def setPty(self, pty): - ttyname = os.ttyname(pty) - self.feed_child("set inferior-tty %s\n" % (ttyname,)) - def setRun(self): argv = string.join(string.split(self.clientCmd)[1:]) self.feed_child("run " + argv + "\n") @@ -45,6 +41,12 @@ class GdbTerminal (DbgTerminal.DbgTerminal): self.waitForNewline() self.feed_child("y\n"); + def setPty(self, pty): + ttyname = os.ttyname(pty) + len = self.getHistoryLen() + self.feed_child("set inferior-tty %s\n" % (ttyname,)) + self.waitForPrompt(len) + def setBreakpoint(self, file, lineno, condition=None): his = self.getHistoryLen() if condition==None: @@ -53,7 +55,7 @@ class GdbTerminal (DbgTerminal.DbgTerminal): self.feed_child("break %s:%s if %s\n" % \ (file, str(lineno), condition)) - rx = re.compile("^Breakpoint |^No |^\(gdb\) ") + rx = "^Breakpoint |^No |^\(gdb\) " his, response = self.waitForRx(rx, his) answer = None @@ -66,7 +68,7 @@ class GdbTerminal (DbgTerminal.DbgTerminal): self.feed_child("n\n"); #Wait again for (gdb)... - self.waitForActivation(his) + self.waitForPrompt(his) return answer @@ -74,12 +76,12 @@ class GdbTerminal (DbgTerminal.DbgTerminal): def delBreakpoint(self, breakpoint): his = self.getHistoryLen() self.feed_child("del breakpoint %s\n" % (breakpoint,)) - self.waitForActivation(his) + self.waitForPrompt(his) def getBreakpoints(self): starthis = self.getHistoryLen() self.feed_child("info breakpoints\n") - endhis, response = self.__waitForPrompt(starthis) + endhis, response = self.waitForPrompt(starthis) rxbp = re.compile("^\d+\s+breakpoint") rxpos = re.compile("^.* at \S+:\d+$") @@ -102,8 +104,7 @@ class GdbTerminal (DbgTerminal.DbgTerminal): #This line does not contain the file! if not rxpos.search(line): - i += 1 - line = bplines[i] + continue pos = string.split(line)[-1] [file,lineno] = string.split(pos,":") @@ -112,7 +113,7 @@ class GdbTerminal (DbgTerminal.DbgTerminal): if i+1