2014-05-16 23:31:09 +03:00
|
|
|
|
2014-05-17 22:43:18 +03:00
|
|
|
"Returns the visually selected text
|
2014-05-16 23:31:09 +03:00
|
|
|
function! vebugger#util#get_visual_selection()
|
2014-05-17 22:43:18 +03:00
|
|
|
"Shamefully stolen from http://stackoverflow.com/a/6271254/794380
|
2014-05-16 23:31:09 +03:00
|
|
|
" Why is this not a built-in Vim script function?!
|
|
|
|
let [lnum1, col1] = getpos("'<")[1:2]
|
|
|
|
let [lnum2, col2] = getpos("'>")[1:2]
|
|
|
|
let lines = getline(lnum1, lnum2)
|
|
|
|
let lines[-1] = lines[-1][: col2 - (&selection == 'inclusive' ? 1 : 2)]
|
|
|
|
let lines[0] = lines[0][col1 - 1:]
|
|
|
|
return join(lines, "\n")
|
|
|
|
endfunction
|
|
|
|
|
2014-05-17 22:43:18 +03:00
|
|
|
"Prompts the user with a filtered list of process, and returns the process id
|
|
|
|
"the user selects
|
2014-05-16 23:31:09 +03:00
|
|
|
function! vebugger#util#selectProcessOfFile(ofFile)
|
|
|
|
let l:fileName=fnamemodify(a:ofFile,':t')
|
2014-05-22 17:11:54 +03:00
|
|
|
if has('win32')
|
|
|
|
"Get the process data in CSV format
|
|
|
|
let l:resultLines=split(vimproc#system('tasklist /FO csv /FI "IMAGENAME eq '.l:fileName.'"'),'\r\n\|\n\|\r')
|
|
|
|
|
|
|
|
if l:resultLines[0]=~'\V\^INFO:'
|
|
|
|
throw 'No matching process found'
|
|
|
|
endif
|
|
|
|
"Parse(sort of) the CSV:
|
|
|
|
let l:resultLinesParsed=map(l:resultLines,'eval("[".v:val."]")')
|
|
|
|
let l:resultLinesParsed[0][2]='Session'
|
|
|
|
"Format for output
|
|
|
|
let l:linesForPrinting=map(copy(l:resultLinesParsed),'v:val[1]."\t".v:val[2]."\t\t".v:val[0]')
|
|
|
|
else
|
|
|
|
let l:resultLines=split(vimproc#system('ps -o pid,user,comm,start,state,tt -C '.fnameescape(l:fileName)),'\r\n\|\n\|\r')
|
|
|
|
let l:linesForPrinting=copy(l:resultLines)
|
|
|
|
endif
|
|
|
|
|
|
|
|
if len(l:linesForPrinting)<=1
|
2014-05-16 23:31:09 +03:00
|
|
|
throw 'No matching process found'
|
|
|
|
endif
|
2014-05-22 17:11:54 +03:00
|
|
|
if &lines<len(l:linesForPrinting)
|
2014-05-16 23:31:09 +03:00
|
|
|
throw 'Too many matching processes found'
|
|
|
|
endif
|
2014-05-22 17:11:54 +03:00
|
|
|
|
|
|
|
"Add numbers to the lines
|
|
|
|
for l:i in range(1,len(l:linesForPrinting)-1)
|
|
|
|
let l:linesForPrinting[l:i]=repeat(' ',3-len(l:i)).l:i.') '.(l:linesForPrinting[l:i])
|
2014-05-16 23:31:09 +03:00
|
|
|
endfor
|
2014-05-22 17:11:54 +03:00
|
|
|
"Indent the title line(since it doesn't have a number)
|
|
|
|
let l:linesForPrinting[0]=' '.l:linesForPrinting[0]
|
|
|
|
|
|
|
|
"Get the selection
|
|
|
|
let l:chosenId=inputlist(l:linesForPrinting)
|
2014-05-16 23:31:09 +03:00
|
|
|
if l:chosenId<1
|
|
|
|
\|| len(l:resultLines)<=l:chosenId
|
|
|
|
return 0
|
|
|
|
endif
|
2014-05-22 17:11:54 +03:00
|
|
|
|
|
|
|
if has('win32')
|
|
|
|
return str2nr(l:resultLinesParsed[l:chosenId][1])
|
|
|
|
else
|
|
|
|
let l:chosenLine=l:resultLines[l:chosenId]
|
2015-02-16 00:41:08 +02:00
|
|
|
let g:chosenLine = l:chosenLine
|
|
|
|
return str2nr(matchstr(l:chosenLine,'\v^\s*\zs(\d+)\ze\s*'))
|
2014-05-22 17:11:54 +03:00
|
|
|
endif
|
2014-05-16 23:31:09 +03:00
|
|
|
endfunction
|
2014-05-17 19:23:15 +03:00
|
|
|
|
2014-05-17 22:43:18 +03:00
|
|
|
"Escape args(from a debugger's extra arguments) as a command line arguments
|
|
|
|
"string
|
2014-05-17 19:23:15 +03:00
|
|
|
function! vebugger#util#commandLineArgsForProgram(debuggerArgs)
|
|
|
|
if has_key(a:debuggerArgs,'args')
|
|
|
|
if type(a:debuggerArgs.args)==type([])
|
|
|
|
return join(map(a:debuggerArgs.args,'s:argEscape(v:val)'),' ')
|
|
|
|
elseif type(a:debuggerArgs.args)==type('')
|
|
|
|
return a:debuggerArgs.args
|
|
|
|
else
|
|
|
|
return string(a:debuggerArgs.args)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
|
2014-05-17 22:43:18 +03:00
|
|
|
"Escape a single argument for the command line
|
2014-05-17 19:23:15 +03:00
|
|
|
function! s:argEscape(arg)
|
|
|
|
if has('win32')
|
|
|
|
return shellescape(a:arg)
|
|
|
|
else
|
|
|
|
return '"'.escape(a:arg,'"').'"'
|
|
|
|
end
|
|
|
|
endfunction
|
2014-05-22 19:14:34 +03:00
|
|
|
|
|
|
|
"Return a tool's(usually debugger) full path, or revert to default if that
|
|
|
|
"path is not defined
|
2014-06-24 01:46:03 +03:00
|
|
|
function! vebugger#util#getToolFullPath(toolName,version,default)
|
2014-05-22 19:14:34 +03:00
|
|
|
let l:optionName='vebugger_path_'.a:toolName
|
2014-06-24 01:46:03 +03:00
|
|
|
if !empty(a:version)
|
|
|
|
let l:optionName=l:optionName.'_'.a:version
|
|
|
|
endif
|
2014-05-22 19:14:34 +03:00
|
|
|
if exists('g:'.l:optionName)
|
|
|
|
return g:[l:optionName]
|
|
|
|
else
|
2014-06-24 01:46:03 +03:00
|
|
|
if type({})==type(a:default)
|
|
|
|
if !empty(a:version) && has_key(a:default,a:version)
|
|
|
|
return a:default[a:version]
|
|
|
|
else
|
|
|
|
return a:default[' ']
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
return a:default
|
|
|
|
endif
|
2014-05-22 19:14:34 +03:00
|
|
|
endif
|
|
|
|
endfunction
|
2014-06-09 21:36:38 +03:00
|
|
|
|
|
|
|
"Checks if the path is an absolute path
|
|
|
|
function! vebugger#util#isPathAbsolute(path)
|
|
|
|
if has('win32')
|
|
|
|
return a:path=~':' || a:path[0]=='%' "Absolute paths in Windows contain : or start with an environment variable
|
|
|
|
else
|
|
|
|
return a:path[0]=~'\v^[/~$]' "Absolute paths in Linux start with ~(home),/(root dir) or $(environment variable)
|
|
|
|
endif
|
|
|
|
endfunction
|
2017-10-16 20:11:15 -02:00
|
|
|
|
|
|
|
function! vebugger#util#listify(stringOrList)
|
|
|
|
if type(a:stringOrList) == type([])
|
|
|
|
return copy(a:stringOrList) " so it could safely be modified by map&filter
|
|
|
|
else
|
|
|
|
return [a:stringOrList]
|
|
|
|
endif
|
|
|
|
endfunction
|
|
|
|
|
2018-04-21 21:09:20 +03:00
|
|
|
function! s:listSigns(filter) abort
|
|
|
|
let l:result = []
|
2018-09-09 07:08:05 +09:00
|
|
|
|
|
|
|
let l:lang = matchstr(execute('language messages'), '"\zs.*\ze"')
|
|
|
|
if l:lang !~ 'en' | language messages en_US.utf8 | endif
|
|
|
|
let l:lines = execute('sign place '.a:filter)
|
|
|
|
if l:lang !~ 'en' | language messages l:lang | endif
|
|
|
|
|
2018-09-08 21:03:49 +09:00
|
|
|
for l:line in split(l:lines, '\n')
|
2018-04-21 21:09:20 +03:00
|
|
|
let l:match = matchlist(l:line, '\C\v^\s+line\=(\d+)\s+id\=(\d+)\s+name\=(.+)$')
|
|
|
|
if !empty(l:match)
|
|
|
|
call add(l:result, {
|
|
|
|
\ 'line': str2nr(l:match[1]),
|
|
|
|
\ 'id': str2nr(l:match[2]),
|
|
|
|
\ 'name': l:match[3],
|
|
|
|
\ })
|
|
|
|
endif
|
|
|
|
endfor
|
|
|
|
return l:result
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! vebugger#util#listSignsInBuffer(bufnr) abort
|
|
|
|
return s:listSigns('buffer='.a:bufnr)
|
|
|
|
endfunction
|
|
|
|
|
|
|
|
function! vebugger#util#listSignsInFile(filename) abort
|
|
|
|
return s:listSigns('file='.a:filename)
|
|
|
|
endfunction
|