fix bug: open non-open files in vim
[pygdb.git] / pygdb.vim
index b38a173115aca00226ac05589e4039b49f6ac3d9..fc03b84404d48cf050f4f1116db99c5aeec2c6f2 100644 (file)
--- a/pygdb.vim
+++ b/pygdb.vim
@@ -9,52 +9,39 @@ let s:ScriptLocation = expand("<sfile>")
 python << >>
 
 import gtk
+import os
 import string
 import sys
 import threading
-
 import vim
 
-#Do not use a ~ for home directory
-sys.path.append("/home/shuber/projekte/pygdb/")
+import Configuration
 
-import GdbTerminal
-import MainControlWindow
-import StatusWindow
 
 
-#Breakpoint positions: List of dictionaries of form {"signnum" : , "file" : , "lineno":, "cond" : }
+#Breakpoint positions: List of dictionaries of form
+#{"signnum" : , "file" : , "lineno":, "cond" : }
 gdbBps = []
 signnum = 0
 clientcmd = ""
 
-gdbterm = None
-mainctrlwnd = None
-statuswnd = None
-gdbthread = None
-
-
-
 def gdbLaunch():
        global gdbterm, mainctrlwnd, statuswnd, gdbBps, clientcmd, gdbthread
 
-       if gdbterm == None:
+       clientcmd = vim.eval("input('Client commando: ', '%s')" % clientcmd).strip()
 
-               clientcmd = vim.eval("input('Client commando: ', '%s')" % clientcmd)
-               gdbterm = GdbTerminal.GdbTerminal(clientcmd)
-               mainctrlwnd = MainControlWindow.MainControlWindow(gdbterm, quitonclose=False)
-               statuswnd = StatusWindow.StatusWindow(mainctrlwnd, gdbterm, quitonclose=False)
-               gdbterm.initialize()
+       if clientcmd.strip()=="":
+               print "No command given!"
+               return
 
-
-               for bp in gdbBps:
-                       statuswnd.breakpointsFrame.addBreakpoint(bp["file"], bp["lineno"], bp["cond"])
-
-               gtk.main()
-               gtk.main()
-               print "hello"
-               #mainctrlwnd.hide()
-               #statuswnd.hide()
+       #Add the breakpoints to the configuration
+       conf = Configuration.Configuration()
+       conf.load(".pygdb.conf")
+       for bp in gdbBps:
+               conf.addBreak(bp["file"], bp["lineno"], bp["cond"])
+       conf.store(".pygdb.conf")
+       
+       vim.command("!python %s/pygdb.py %s &\n" % (pygdbdir, clientcmd))
 
 
 def gdbToggleBreakpoint(lineno=None, file=None):
@@ -64,25 +51,49 @@ def gdbToggleBreakpoint(lineno=None, file=None):
        if lineno==None:
                lineno = vim.current.window.cursor[0]
        if file==None:
-               file = vim.current.window.buffer.name
+               file = getCurrentFile()
 
        #Determine index of breakpoint
        bpidx = gdbGetBreakpoint( file, lineno )
 
-       #Remove the breakpoint
        if bpidx != None:
-               vim.command("sign unplace %(signnum)d" % gdbBps[bpidx])
-               del gdbBps[bpidx]
-
-       #Create the breakpoint
+               removeBreakpoint(bpidx)
        else:
-               #Determine a sign number
-               signnum = gdbNewSignnum()
+               addBreakpoint(file, lineno)
+
+
+def addBreakpoint(file, lineno, cond=None):
+       global gdbBps
+
+       #If file is not open, open it
+       if not file in [b.name for b in vim.buffers]:
+               try:
+                       os.stat(file)
+                       vim.command(":e %s" % file)
+               except OSError:
+                       print "Warning: file '%s' does not exist! (Wrong client command?)" % file
+                       return
+
+
+       #Determine a sign number
+       signnum = gdbNewSignnum()
 
-               #Create breakpoint and add sign
-               b = {"signnum" : signnum, "lineno" : lineno, "file" : file, "cond" : None}
+       #Create breakpoint and add sign
+       b = {"signnum" : signnum, "lineno" : lineno, "file" : file, "cond" : cond}
+       gdbBps += [b]
+
+       if cond == None:
                vim.command("sign place %(signnum)d line=%(lineno)d name=BreakPoint file=%(file)s" % b)
-               gdbBps += [b]
+       else:
+               vim.command("sign place %(signnum)d line=%(lineno)d name=CondBreakPoint file=%(file)s" % b)
+
+               
+
+def removeBreakpoint(idx):
+       global gdbBps
+
+       vim.command("sign unplace %(signnum)d" % gdbBps[idx])
+       del gdbBps[idx]
 
 
 def gdbBreakpointCond(lineno=None, file=None, cond=None):
@@ -92,29 +103,25 @@ def gdbBreakpointCond(lineno=None, file=None, cond=None):
        if lineno==None:
                lineno = vim.current.window.cursor[0]
        if file==None:
-               file = vim.current.window.buffer.name
+               file = getCurrentFile()
 
        #Determine index of breakpoint
        bpidx = gdbGetBreakpoint( file, lineno )
 
-       #Remove the breakpoint
+       #Alter condition
        if bpidx != None:
-               if cond == None:
-                       cond = vim.eval("input('Breakpoint condition: ', '%s')" % gdbBps[bpidx]["cond"])
-               gdbBps[bpidx]["cond"] = cond
-
+               gdbBps[bpidx]["cond"] = vim.eval("input('Breakpoint condition: ', '%s')" % gdbBps[bpidx]["cond"])
+       #Set new breakpoint
        else:
-               #Determine a sign number
-               signnum = gdbNewSignnum()
-
                #Get condition
-               if cond == None:
-                       cond = vim.eval("input('Breakpoint condition: ', '')")
-               
-               #Create breakpoint and add sign
-               b = {"signnum" : signnum, "lineno" : lineno, "file" : file, "cond" : cond}
-               vim.command("sign place %(signnum)d line=%(lineno)d name=CondBreakPoint file=%(file)s" % b)
-               gdbBps += [b]
+               cond = vim.eval("input('Breakpoint condition: ', '')")
+               #Add the breakpoint
+               addBreakpoint(file, lineno, cond)
+
+
+def getCurrentFile():
+       return vim.current.window.buffer.name
+
 
 
 def gdbNewSignnum():
@@ -129,14 +136,82 @@ def gdbGetBreakpoint(file, lineno):
                        return i        
        return None
 
+def gdbShowBreakpoints():
+       global gdbBps
+
+       if len(gdbBps) == 0:
+               print "No breakpoints set."
+       else:
+               print "%d breakpoints set:" % len(gdbBps)
+
+       for bp in gdbBps:
+               if bp["cond"] != None:
+                       print "%(file)s:%(lineno)d if %(cond)s" % bp
+               else:
+                       print "%(file)s:%(lineno)d" % bp
+
+
+def getAbsPath(absfile, relfile):
+       """When an absfile is given and a relfile is given by
+       relative paths relative to absfile, determine the abs
+       path of relfile"""
+
+       #Get directories except for "." parts
+       relsplit = filter(lambda x: x!=".", string.split(relfile, os.sep))
+       #Get the directories of absfile withouth the trailing filename 
+       abssplit = string.split(absfile, os.sep)[:-1]
+
+       #Determine number of ".." and remove them
+       up=0
+       while relsplit[0] == "..":
+               up += 1
+               del relsplit[0]
+               del abssplit[-1]
+
+       return string.join(abssplit + relsplit, os.sep)
+
+
+
+def gdbLoadConfig():
+       global clientcmd, gdbBps
+
+
+       #Load configuration
+       conf = Configuration.Configuration()
+       conf.load(".pygdb.conf")
+
+       #Remove all breakpoints
+       while len(gdbBps)>0:
+               removeBreakpoint(0)
+
+       #Add breakpoints from configuration
+       cmdset = False
+       for bp in conf.breakpoints:
+
+               file = bp["file"]
+
+               #Not a absolute path --> make one
+               if file[0] != os.sep:
+
+                       #We need the client command to expand the paths...
+                       while clientcmd == "" or not cmdset:
+                               clientcmd = vim.eval("input('Client commando: ', '%s')" % clientcmd).strip()
+                               cmdset = True
+
+                       #Get the dirs where executeable is in
+                       relcmd = string.split(clientcmd)[0]
+                       abscmd = getAbsPath(getCurrentFile(), relcmd)
+                       bp["file"] = file = getAbsPath(abscmd, file)
+
+                       assert(file[0] == "/")
+
+               addBreakpoint(bp["file"], bp["lineno"], bp["cond"])
 
 >>
 
 
-highlight ExecutionLine term=bold ctermbg=DarkGreen ctermfg=White
 highlight BreakPoint term=inverse ctermbg=DarkCyan ctermfg=Black
 
-sign define ExecutionLine text==> texthl=ExecutionLine linehl=ExecutionLine
 sign define BreakPoint text=! texthl=BreakPoint linehl=BreakPoint
 sign define CondBreakPoint text=? texthl=BreakPoint linehl=BreakPoint
 
@@ -145,13 +220,17 @@ sign define CondBreakPoint text=? texthl=BreakPoint linehl=BreakPoint
 command! GDBLaunch :python gdbLaunch()
 command! GDBToggleBreakpoint :python gdbToggleBreakpoint()
 command! GDBBreakpointCond :python gdbBreakpointCond()
+command! GDBShowBreakpoints :python gdbShowBreakpoints()
+command! GDBLoadConfig :python gdbLoadConfig()
 
 
 
 function! GDBMapDefaults()
        nmap <silent> <F5>              :GDBLaunch<CR>
        nmap <silent> <F8>              :GDBToggleBreakpoint<CR>
-       nmap <silent> <F9>              :GDBBreakpointCond<CR>
+       nmap <silent> <S-F8>            :GDBBreakpointCond<CR>
+       nmap <silent> <F9>              :GDBShowBreakpoints<CR>
+       nmap <silent> <S-F9>            :GDBLoadConfig<CR>
 endfunction