mirror of
https://github.com/amix/vimrc
synced 2024-12-13 21:52:38 +00:00
161 lines
5.2 KiB
VimL
161 lines
5.2 KiB
VimL
function! go#tool#Files()
|
|
if go#util#IsWin()
|
|
let command = 'go list -f "{{range $f := .GoFiles}}{{$.Dir}}\{{$f}}{{printf \"\n\"}}{{end}}{{range $f := .CgoFiles}}{{$.Dir}}\{{$f}}{{printf \"\n\"}}{{end}}"'
|
|
else
|
|
let command = "go list -f '{{range $f := .GoFiles}}{{$.Dir}}/{{$f}}{{printf \"\\n\"}}{{end}}{{range $f := .CgoFiles}}{{$.Dir}}/{{$f}}{{printf \"\\n\"}}{{end}}'"
|
|
endif
|
|
let out = go#tool#ExecuteInDir(command)
|
|
return split(out, '\n')
|
|
endfunction
|
|
|
|
function! go#tool#Deps()
|
|
if go#util#IsWin()
|
|
let command = 'go list -f "{{range $f := .Deps}}{{$f}}{{printf \"\n\"}}{{end}}"'
|
|
else
|
|
let command = "go list -f $'{{range $f := .Deps}}{{$f}}\n{{end}}'"
|
|
endif
|
|
let out = go#tool#ExecuteInDir(command)
|
|
return split(out, '\n')
|
|
endfunction
|
|
|
|
function! go#tool#Imports()
|
|
let imports = {}
|
|
if go#util#IsWin()
|
|
let command = 'go list -f "{{range $f := .Imports}}{{$f}}{{printf \"\n\"}}{{end}}"'
|
|
else
|
|
let command = "go list -f $'{{range $f := .Imports}}{{$f}}\n{{end}}'"
|
|
endif
|
|
let out = go#tool#ExecuteInDir(command)
|
|
if v:shell_error
|
|
echo out
|
|
return imports
|
|
endif
|
|
|
|
for package_path in split(out, '\n')
|
|
let cmd = "go list -f {{.Name}} " . package_path
|
|
let package_name = substitute(go#tool#ExecuteInDir(cmd), '\n$', '', '')
|
|
let imports[package_name] = package_path
|
|
endfor
|
|
|
|
return imports
|
|
endfunction
|
|
|
|
function! go#tool#ShowErrors(out)
|
|
" cd into the current files directory. This is important so fnamemodify
|
|
" does create a full path for outputs when the token is only a single file
|
|
" name (such as for a go test output, i.e.: 'demo_test.go'). For other
|
|
" outputs, such as 'go install' we already get an absolute path (i.e.:
|
|
" '../foo/foo.go') and fnamemodify successfuly creates the full path.
|
|
let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd '
|
|
let current_dir = getcwd()
|
|
execute cd . fnameescape(expand("%:p:h"))
|
|
|
|
let errors = []
|
|
|
|
for line in split(a:out, '\n')
|
|
let fatalerrors = matchlist(line, '^\(fatal error:.*\)$')
|
|
let tokens = matchlist(line, '^\s*\(.\{-}\):\(\d\+\):\s*\(.*\)')
|
|
|
|
if !empty(fatalerrors)
|
|
call add(errors, {"text": fatalerrors[1]})
|
|
elseif !empty(tokens)
|
|
call add(errors, {"filename" : fnamemodify(tokens[1], ':p'),
|
|
\"lnum": tokens[2],
|
|
\"text": tokens[3]})
|
|
elseif !empty(errors)
|
|
" Preserve indented lines.
|
|
" This comes up especially with multi-line test output.
|
|
if match(line, '^\s') >= 0
|
|
call add(errors, {"text": line})
|
|
endif
|
|
endif
|
|
endfor
|
|
|
|
" return back to old dir once we are finished with populating the errors
|
|
execute cd . fnameescape(current_dir)
|
|
|
|
if !empty(errors)
|
|
call setqflist(errors, 'r')
|
|
return
|
|
endif
|
|
|
|
if empty(errors)
|
|
" Couldn't detect error format, output errors
|
|
echo a:out
|
|
endif
|
|
endfunction
|
|
|
|
function! go#tool#ExecuteInDir(cmd) abort
|
|
let old_gopath = $GOPATH
|
|
let $GOPATH = go#path#Detect()
|
|
|
|
let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd '
|
|
let dir = getcwd()
|
|
try
|
|
execute cd . fnameescape(expand("%:p:h"))
|
|
let out = system(a:cmd)
|
|
finally
|
|
execute cd . fnameescape(dir)
|
|
endtry
|
|
|
|
let $GOPATH = old_gopath
|
|
return out
|
|
endfunction
|
|
|
|
" Exists checks whether the given importpath exists or not. It returns 0 if
|
|
" the importpath exists under GOPATH.
|
|
function! go#tool#Exists(importpath)
|
|
let command = "go list ". a:importpath
|
|
let out = go#tool#ExecuteInDir(command)
|
|
|
|
if v:shell_error
|
|
return -1
|
|
endif
|
|
|
|
return 0
|
|
endfunction
|
|
|
|
|
|
" following two functions are from: https://github.com/mattn/gist-vim
|
|
" thanks @mattn
|
|
function! s:get_browser_command()
|
|
let go_play_browser_command = get(g:, 'go_play_browser_command', '')
|
|
if go_play_browser_command == ''
|
|
if go#util#IsWin()
|
|
let go_play_browser_command = '!start rundll32 url.dll,FileProtocolHandler %URL%'
|
|
elseif has('mac') || has('macunix') || has('gui_macvim') || system('uname') =~? '^darwin'
|
|
let go_play_browser_command = 'open %URL%'
|
|
elseif executable('xdg-open')
|
|
let go_play_browser_command = 'xdg-open %URL%'
|
|
elseif executable('firefox')
|
|
let go_play_browser_command = 'firefox %URL% &'
|
|
else
|
|
let go_play_browser_command = ''
|
|
endif
|
|
endif
|
|
return go_play_browser_command
|
|
endfunction
|
|
|
|
function! go#tool#OpenBrowser(url)
|
|
let cmd = s:get_browser_command()
|
|
if len(cmd) == 0
|
|
redraw
|
|
echohl WarningMsg
|
|
echo "It seems that you don't have general web browser. Open URL below."
|
|
echohl None
|
|
echo a:url
|
|
return
|
|
endif
|
|
if cmd =~ '^!'
|
|
let cmd = substitute(cmd, '%URL%', '\=shellescape(a:url)', 'g')
|
|
silent! exec cmd
|
|
elseif cmd =~ '^:[A-Z]'
|
|
let cmd = substitute(cmd, '%URL%', '\=a:url', 'g')
|
|
exec cmd
|
|
else
|
|
let cmd = substitute(cmd, '%URL%', '\=shellescape(a:url)', 'g')
|
|
call system(cmd)
|
|
endif
|
|
endfunction
|
|
|
|
" vim:ts=4:sw=4:et
|