Added shell buffer support for JDB
This commit is contained in:
parent
9fae72d993
commit
fe16f3925c
@ -9,9 +9,11 @@ function! vebugger#jdb#start(entryClass,args)
|
|||||||
let l:debugger.state.jdb.filesToClassesMap={}
|
let l:debugger.state.jdb.filesToClassesMap={}
|
||||||
|
|
||||||
call l:debugger.writeLine('stop on '.a:entryClass.'.main')
|
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('run '.a:entryClass.' '.vebugger#util#commandLineArgsForProgram(a:args))
|
||||||
call l:debugger.writeLine('monitor where')
|
call l:debugger.writeLine('monitor where')
|
||||||
|
call vebugger#std#openShellBuffer(l:debugger)
|
||||||
|
|
||||||
|
call l:debugger.addReadHandler(function('s:readProgramOutput'))
|
||||||
call l:debugger.addReadHandler(function('s:readWhere'))
|
call l:debugger.addReadHandler(function('s:readWhere'))
|
||||||
call l:debugger.addReadHandler(function('s:readException'))
|
call l:debugger.addReadHandler(function('s:readException'))
|
||||||
call l:debugger.addReadHandler(function('s:readEvaluatedExpressions'))
|
call l:debugger.addReadHandler(function('s:readEvaluatedExpressions'))
|
||||||
@ -28,6 +30,29 @@ function! vebugger#jdb#start(entryClass,args)
|
|||||||
return l:debugger
|
return l:debugger
|
||||||
endfunction
|
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)
|
function! s:findFolderFromStackTrace(src,nameFromStackTrace)
|
||||||
let l:path=a:src
|
let l:path=a:src
|
||||||
for l:dirname in split(a:nameFromStackTrace,'\.')
|
for l:dirname in split(a:nameFromStackTrace,'\.')
|
||||||
|
Loading…
x
Reference in New Issue
Block a user