X-Git-Url: https://git.sthu.org/?a=blobdiff_plain;f=GdbTerminal.py;h=ff6dc6b37356133c8d526fbb1f02f9f0dd6c9d3a;hb=379760912de740354f07f223b308d5092c0700ad;hp=f468f89fe1f718fb99e870bf3b21abe0b10ff2b9;hpb=d7a00b7d9d8b49655f714abc53361bed08e0355d;p=pygdb.git diff --git a/GdbTerminal.py b/GdbTerminal.py old mode 100755 new mode 100644 index f468f89..ff6dc6b --- a/GdbTerminal.py +++ b/GdbTerminal.py @@ -23,38 +23,30 @@ class GdbTerminal (DbgTerminal.DbgTerminal): def getArgv(self): return ["gdb", "--fullname", string.split(self.clientCmd)[0]] - def setPty(self, pty): - ttyname = os.ttyname(pty) - his = self.getHistoryLen() - self.feed_child("set inferior-tty %s\n" % (ttyname,)) - self.waitForActivation(his) - def setRun(self): - his = self.getHistoryLen() argv = string.join(string.split(self.clientCmd)[1:]) self.feed_child("run " + argv + "\n") - return self.waitForActivation(his) def setContinue(self): - his = self.getHistoryLen() self.feed_child("cont\n"); - return self.waitForActivation(his) def setStepover(self): - his = self.getHistoryLen() self.feed_child("next\n"); - return self.waitForActivation(his) def setStepin(self): - his = self.getHistoryLen() self.feed_child("step\n"); - return self.waitForActivation(his) def setQuit(self): self.feed_child("quit\n") 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: @@ -63,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 @@ -76,7 +68,7 @@ class GdbTerminal (DbgTerminal.DbgTerminal): self.feed_child("n\n"); #Wait again for (gdb)... - self.waitForActivation(his) + self.waitForPrompt(his) return answer @@ -84,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+$") @@ -112,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,":") @@ -122,7 +113,7 @@ class GdbTerminal (DbgTerminal.DbgTerminal): if i+1