function! vebugger#jdb#start(entryClass,args) let l:debugger=vebugger#std#startDebugger(shellescape(vebugger#util#getToolFullPath('jdb','jdb')) \.(has_key(a:args,'classpath') ? ' -classpath '.fnameescape(a:args.classpath) : '')) let l:debugger.state.jdb={} if has_key(a:args,'srcpath') let l:debugger.state.jdb.srcpath=a:args.srcpath else let l:debugger.state.jdb.srcpath='.' endif let l:debugger.state.jdb.filesToClassesMap={} call l:debugger.writeLine('stop on '.a:entryClass.'.main') call l:debugger.writeLine('run '.a:entryClass.' '.vebugger#util#commandLineArgsForProgram(a:args)) call l:debugger.writeLine('monitor where') if !has('win32') call vebugger#std#openShellBuffer(l:debugger) endif call l:debugger.addReadHandler(function('s:readProgramOutput')) call l:debugger.addReadHandler(function('s:readWhere')) call l:debugger.addReadHandler(function('s:readException')) call l:debugger.addReadHandler(function('s:readEvaluatedExpressions')) call l:debugger.setWriteHandler('std','flow',function('s:writeFlow')) call l:debugger.setWriteHandler('std','breakpoints',function('s:writeBreakpoints')) call l:debugger.setWriteHandler('std','evaluateExpressions',function('s:requestEvaluateExpression')) call l:debugger.setWriteHandler('std','executeStatements',function('s:executeStatements')) call l:debugger.generateWriteActionsFromTemplate() call l:debugger.std_addAllBreakpointActions(g:vebugger_breakpoints) return l:debugger endfunction function! s:readProgramOutput(pipeName,line,readResult,debugger) dict if 'out'==a:pipeName if a:line=~'\v^\> \>' \||a:line=='> ' \||a:line=~'\v^Step completed' \||a:line=~'\v^Breakpoint hit' \||a:line=~'\v^\> Deferring breakpoint' \||a:line=='Nothing suspended.' \||a:line=~'\v^\> run ' "Signs that the output finished let self.programOutputMode=0 elseif a:line=~'\v(step|step up|next|cont)$' "Next line should be output let self.programOutputMode=1 elseif a:line=~'\v^\> [^>]' "Start of output let a:readResult.std.programOutput={'line':substitute(a:line,'\v^\> ','','')} let self.programOutputMode=1 elseif get(self,'programOutputMode') let a:readResult.std.programOutput={'line':a:line} endif else let a:readResult.std.programOutput={'line':a:line} endif endfunction function! s:findFolderFromStackTrace(src,nameFromStackTrace) let l:path=a:src for l:dirname in split(a:nameFromStackTrace,'\.') let l:nextPath=l:path.'/'.fnameescape(l:dirname) if empty(glob(l:nextPath)) return l:path endif let l:path=l:nextPath endfor return l:path endfunction function! s:readWhere(pipeName,line,readResult,debugger) if 'out'==a:pipeName let l:matches=matchlist(a:line,'\v\s*\[(\d+)]\s*(\S+)\s*\(([^:]*):(\d*)\)') if 4