mirror of
				https://github.com/amix/vimrc
				synced 2025-10-31 06:33:35 +08:00 
			
		
		
		
	Updated vim plugins
This commit is contained in:
		| @ -4,7 +4,7 @@ function! go#cmd#autowrite() abort | ||||
|   endif | ||||
| endfunction | ||||
|  | ||||
| " Build builds the source code without producting any output binary. We live in | ||||
| " Build builds the source code without producing any output binary. We live in | ||||
| " an editor so the best is to build it to catch errors and fix them. By | ||||
| " default it tries to call simply 'go build', but it first tries to get all | ||||
| " dependent files for the current folder and passes it to go build. | ||||
| @ -18,8 +18,10 @@ function! go#cmd#Build(bang, ...) abort | ||||
|   endif | ||||
|   " create our command arguments. go build discards any results when it | ||||
|   " compiles multiple packages. So we pass the `errors` package just as an | ||||
|   " placeholder with the current folder (indicated with '.') | ||||
|   let args = ["build"]  + goargs + [".", "errors"] | ||||
|   " placeholder with the current folder (indicated with '.'). We also pass -i | ||||
|   " that tries to install the dependencies, this has the side effect that it | ||||
|   " caches the build results, so every other build is faster. | ||||
|   let args = ["build"]  + goargs + ["-i", ".", "errors"] | ||||
|  | ||||
|   if go#util#has_job() | ||||
|     if get(g:, 'go_echo_command_info', 1) | ||||
| @ -109,7 +111,7 @@ function! go#cmd#RunTerm(bang, mode, files) abort | ||||
| endfunction | ||||
|  | ||||
| " Run runs the current file (and their dependencies if any) and outputs it. | ||||
| " This is intented to test small programs and play with them. It's not | ||||
| " This is intended to test small programs and play with them. It's not | ||||
| " suitable for long running apps, because vim is blocking by default and | ||||
| " calling long running apps will block the whole UI. | ||||
| function! go#cmd#Run(bang, ...) abort | ||||
| @ -225,145 +227,6 @@ function! go#cmd#Install(bang, ...) abort | ||||
|   let &makeprg = default_makeprg | ||||
| endfunction | ||||
|  | ||||
| " Test runs `go test` in the current directory. If compile is true, it'll | ||||
| " compile the tests instead of running them (useful to catch errors in the | ||||
| " test files). Any other argument is appendend to the final `go test` command | ||||
| function! go#cmd#Test(bang, compile, ...) abort | ||||
|   let args = ["test"] | ||||
|  | ||||
|   " don't run the test, only compile it. Useful to capture and fix errors. | ||||
|   if a:compile | ||||
|     let compile_file = "vim-go-test-compile" | ||||
|     call extend(args, ["-c", "-o", compile_file]) | ||||
|   endif | ||||
|  | ||||
|   if a:0 | ||||
|     let goargs = a:000 | ||||
|  | ||||
|     " do not expand for coverage mode as we're passing the arg ourself | ||||
|     if a:1 != '-coverprofile' | ||||
|       " expand all wildcards(i.e: '%' to the current file name) | ||||
|       let goargs = map(copy(a:000), "expand(v:val)") | ||||
|     endif | ||||
|  | ||||
|     if !(has('nvim') || go#util#has_job()) | ||||
|       let goargs = go#util#Shelllist(goargs, 1) | ||||
|     endif | ||||
|  | ||||
|     call extend(args, goargs, 1) | ||||
|   else | ||||
|     " only add this if no custom flags are passed | ||||
|     let timeout  = get(g:, 'go_test_timeout', '10s') | ||||
|     call add(args, printf("-timeout=%s", timeout)) | ||||
|   endif | ||||
|  | ||||
|   if get(g:, 'go_echo_command_info', 1) | ||||
|     if a:compile | ||||
|       echon "vim-go: " | echohl Identifier | echon "compiling tests ..." | echohl None | ||||
|     else | ||||
|       echon "vim-go: " | echohl Identifier | echon "testing ..." | echohl None | ||||
|     endif | ||||
|   endif | ||||
|  | ||||
|   if go#util#has_job() | ||||
|     " use vim's job functionality to call it asynchronously | ||||
|     let job_args = { | ||||
|           \ 'cmd': ['go'] + args, | ||||
|           \ 'bang': a:bang, | ||||
|           \ } | ||||
|  | ||||
|     if a:compile | ||||
|       let job_args['custom_cb'] = function('s:test_compile', [compile_file]) | ||||
|     endif | ||||
|  | ||||
|     call s:cmd_job(job_args) | ||||
|     return | ||||
|   elseif has('nvim') | ||||
|     " use nvims's job functionality | ||||
|     if get(g:, 'go_term_enabled', 0) | ||||
|       let id = go#term#new(a:bang, ["go"] + args) | ||||
|     else | ||||
|       let id = go#jobcontrol#Spawn(a:bang, "test", args) | ||||
|     endif | ||||
|  | ||||
|     if a:compile | ||||
|       call go#jobcontrol#AddHandler(function('s:test_compile_handler')) | ||||
|       let s:test_compile_handlers[id] = compile_file | ||||
|     endif | ||||
|     return id | ||||
|   endif | ||||
|  | ||||
|   call go#cmd#autowrite() | ||||
|   redraw | ||||
|  | ||||
|   let command = "go " . join(args, ' ') | ||||
|   let out = go#tool#ExecuteInDir(command) | ||||
|  | ||||
|   let l:listtype = "quickfix" | ||||
|  | ||||
|   let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd ' | ||||
|   let dir = getcwd() | ||||
|   execute cd fnameescape(expand("%:p:h")) | ||||
|  | ||||
|   if a:compile | ||||
|     call delete(compile_file) | ||||
|   endif | ||||
|  | ||||
|   if go#util#ShellError() != 0 | ||||
|     let errors = go#tool#ParseErrors(split(out, '\n')) | ||||
|     let errors = go#tool#FilterValids(errors) | ||||
|  | ||||
|     call go#list#Populate(l:listtype, errors, command) | ||||
|     call go#list#Window(l:listtype, len(errors)) | ||||
|     if !empty(errors) && !a:bang | ||||
|       call go#list#JumpToFirst(l:listtype) | ||||
|     elseif empty(errors) | ||||
|       " failed to parse errors, output the original content | ||||
|       call go#util#EchoError(out) | ||||
|     endif | ||||
|     echon "vim-go: " | echohl ErrorMsg | echon "[test] FAIL" | echohl None | ||||
|   else | ||||
|     call go#list#Clean(l:listtype) | ||||
|     call go#list#Window(l:listtype) | ||||
|  | ||||
|     if a:compile | ||||
|       echon "vim-go: " | echohl Function | echon "[test] SUCCESS" | echohl None | ||||
|     else | ||||
|       echon "vim-go: " | echohl Function | echon "[test] PASS" | echohl None | ||||
|     endif | ||||
|   endif | ||||
|   execute cd . fnameescape(dir) | ||||
| endfunction | ||||
|  | ||||
| " Testfunc runs a single test that surrounds the current cursor position. | ||||
| " Arguments are passed to the `go test` command. | ||||
| function! go#cmd#TestFunc(bang, ...) abort | ||||
|   " search flags legend (used only) | ||||
|   " 'b' search backward instead of forward | ||||
|   " 'c' accept a match at the cursor position | ||||
|   " 'n' do Not move the cursor | ||||
|   " 'W' don't wrap around the end of the file | ||||
|   " | ||||
|   " for the full list | ||||
|   " :help search | ||||
|   let test = search('func \(Test\|Example\)', "bcnW") | ||||
|  | ||||
|   if test == 0 | ||||
|     echo "vim-go: [test] no test found immediate to cursor" | ||||
|     return | ||||
|   end | ||||
|  | ||||
|   let line = getline(test) | ||||
|   let name = split(split(line, " ")[1], "(")[0] | ||||
|   let args = [a:bang, 0, "-run", name . "$"] | ||||
|  | ||||
|   if a:0 | ||||
|     call extend(args, a:000) | ||||
|   endif | ||||
|  | ||||
|   call call('go#cmd#Test', args) | ||||
| endfunction | ||||
|  | ||||
| " Generate runs 'go generate' in similar fashion to go#cmd#Build() | ||||
| function! go#cmd#Generate(bang, ...) abort | ||||
|   let default_makeprg = &makeprg | ||||
| @ -465,24 +328,4 @@ function s:cmd_job(args) abort | ||||
|   let $GOPATH = old_gopath | ||||
| endfunction | ||||
|  | ||||
|  | ||||
| " test_compile is called when a GoTestCompile call is finished | ||||
| function! s:test_compile(test_file, job, exit_status, data) abort | ||||
|   call delete(a:test_file) | ||||
| endfunction | ||||
|  | ||||
| " ----------------------- | ||||
| " | Neovim job handlers | | ||||
| " ----------------------- | ||||
| let s:test_compile_handlers = {} | ||||
|  | ||||
| function! s:test_compile_handler(job, exit_status, data) abort | ||||
|   if !has_key(s:test_compile_handlers, a:job.id) | ||||
|     return | ||||
|   endif | ||||
|   let l:compile_file = s:test_compile_handlers[a:job.id] | ||||
|   call delete(l:compile_file) | ||||
|   unlet s:test_compile_handlers[a:job.id] | ||||
| endfunction | ||||
|  | ||||
| " vim: sw=2 ts=2 et | ||||
|  | ||||
| @ -103,7 +103,7 @@ function! go#complete#GetInfo() abort | ||||
|     return "" | ||||
|   endif | ||||
|  | ||||
|   " only one candiate is found | ||||
|   " only one candidate is found | ||||
|   if len(out) == 2 | ||||
|     return split(out[1], ',,')[0] | ||||
|   endif | ||||
|  | ||||
| @ -17,7 +17,7 @@ function! go#coverage#BufferToggle(bang, ...) abort | ||||
| endfunction | ||||
|  | ||||
| " Buffer creates a new cover profile with 'go test -coverprofile' and changes | ||||
| " teh current buffers highlighting to show covered and uncovered sections of | ||||
| " the current buffers highlighting to show covered and uncovered sections of | ||||
| " the code. Calling it again reruns the tests and shows the last updated | ||||
| " coverage. | ||||
| function! go#coverage#Buffer(bang, ...) abort | ||||
| @ -44,9 +44,13 @@ function! go#coverage#Buffer(bang, ...) abort | ||||
|   let s:toggle = 1 | ||||
|   let l:tmpname = tempname() | ||||
|  | ||||
|   if get(g:, 'go_echo_command_info', 1) | ||||
|     echon "vim-go: " | echohl Identifier | echon "testing ..." | echohl None | ||||
|   endif | ||||
|  | ||||
|   if go#util#has_job() | ||||
|     call s:coverage_job({ | ||||
|           \ 'cmd': ['go', 'test', '-coverprofile', l:tmpname], | ||||
|           \ 'cmd': ['go', 'test', '-coverprofile', l:tmpname] + a:000, | ||||
|           \ 'custom_cb': function('s:coverage_callback', [l:tmpname]), | ||||
|           \ 'bang': a:bang, | ||||
|           \ }) | ||||
| @ -64,7 +68,7 @@ function! go#coverage#Buffer(bang, ...) abort | ||||
|     let g:go_term_enabled = 0 | ||||
|   endif | ||||
|  | ||||
|   let id = call('go#cmd#Test', args) | ||||
|   let id = call('go#test#Test', args) | ||||
|  | ||||
|   if disabled_term | ||||
|     let g:go_term_enabled = 1 | ||||
| @ -113,7 +117,7 @@ function! go#coverage#Browser(bang, ...) abort | ||||
|     call extend(args, a:000) | ||||
|   endif | ||||
|  | ||||
|   let id = call('go#cmd#Test', args) | ||||
|   let id = call('go#test#Test', args) | ||||
|   if has('nvim') | ||||
|     call go#jobcontrol#AddHandler(function('s:coverage_browser_handler')) | ||||
|     let s:coverage_browser_handler_jobs[id] = l:tmpname | ||||
| @ -212,7 +216,7 @@ function! go#coverage#overlay(file) abort | ||||
|  | ||||
|   " first mark all lines as goCoverageNormalText. We use a custom group to not | ||||
|   " interfere with other buffers highlightings. Because the priority is | ||||
|   " lower than the cover and uncover matches, it'll be overriden. | ||||
|   " lower than the cover and uncover matches, it'll be overridden. | ||||
|   let cnt = 1 | ||||
|   while cnt <= line('$') | ||||
|     call add(matches, {'group': 'goCoverageNormalText', 'pos': [cnt], 'priority': 1}) | ||||
|  | ||||
| @ -46,8 +46,8 @@ function! go#def#Jump(mode) abort | ||||
|       call add(cmd, "-modified") | ||||
|     endif | ||||
|  | ||||
|     if exists('g:go_guru_tags') | ||||
|       let tags = get(g:, 'go_guru_tags') | ||||
|     if exists('g:go_build_tags') | ||||
|       let tags = get(g:, 'go_build_tags') | ||||
|       call extend(cmd, ["-tags", tags]) | ||||
|     endif | ||||
|  | ||||
|  | ||||
| @ -93,8 +93,8 @@ function! s:GodocView(newposition, position, content) abort | ||||
|   endif | ||||
|  | ||||
|   if a:position == "split" | ||||
|     " cap buffer height to 20, but resize it for smaller contents | ||||
|     let max_height = 20 | ||||
|     " cap window height to 20, but resize it for smaller contents | ||||
|     let max_height = get(g:, "go_doc_max_height", 20) | ||||
|     let content_height = len(split(a:content, "\n")) | ||||
|     if content_height > max_height | ||||
|       exe 'resize ' . max_height | ||||
|  | ||||
| @ -9,18 +9,14 @@ if !exists("g:go_fmt_command") | ||||
|   let g:go_fmt_command = "gofmt" | ||||
| endif | ||||
|  | ||||
| if !exists("g:go_goimports_bin") | ||||
|   let g:go_goimports_bin = "goimports" | ||||
| if !exists('g:go_fmt_options') | ||||
|   let g:go_fmt_options = '' | ||||
| endif | ||||
|  | ||||
| if !exists('g:go_fmt_fail_silently') | ||||
|   let g:go_fmt_fail_silently = 0 | ||||
| endif | ||||
|  | ||||
| if !exists('g:go_fmt_options') | ||||
|   let g:go_fmt_options = '' | ||||
| endif | ||||
|  | ||||
| if !exists("g:go_fmt_experimental") | ||||
|   let g:go_fmt_experimental = 0 | ||||
| endif | ||||
| @ -70,7 +66,7 @@ function! go#fmt#Format(withGoimport) abort | ||||
|  | ||||
|   let bin_name = g:go_fmt_command | ||||
|   if a:withGoimport == 1 | ||||
|     let bin_name = g:go_goimports_bin | ||||
|     let bin_name = "goimports" | ||||
|   endif | ||||
|  | ||||
|   let out = go#fmt#run(bin_name, l:tmpname, expand('%')) | ||||
| @ -172,7 +168,15 @@ function! s:fmt_cmd(bin_name, source, target) | ||||
|   " start constructing the command | ||||
|   let cmd = [bin_path] | ||||
|   call add(cmd, "-w") | ||||
|   call extend(cmd, split(g:go_fmt_options, " ")) | ||||
|      | ||||
|   " add the options for binary (if any). go_fmt_options was by default of type | ||||
|   " string, however to allow customization it's now a dictionary of binary | ||||
|   " name mapping to options. | ||||
|   let opts = g:go_fmt_options | ||||
|   if type(g:go_fmt_options) == type({}) | ||||
|     let opts = has_key(g:go_fmt_options, a:bin_name) ? g:go_fmt_options[a:bin_name] : "" | ||||
|   endif | ||||
|   call extend(cmd, split(opts, " ")) | ||||
|  | ||||
|   if a:bin_name == "goimports" | ||||
|     " lazy check if goimports support `-srcdir`. We should eventually remove | ||||
| @ -189,7 +193,9 @@ function! s:fmt_cmd(bin_name, source, target) | ||||
|     if exists('b:goimports_vendor_compatible') && b:goimports_vendor_compatible | ||||
|       let ssl_save = &shellslash | ||||
|       set noshellslash | ||||
|       call extend(cmd, ["-srcdir", shellescape(fnamemodify(a:target, ":p"))]) | ||||
|       " use the filename without the fully qualified name if the tree is | ||||
|       " symlinked into the GOPATH, goimports won't work properly. | ||||
|       call extend(cmd, ["-srcdir", shellescape(a:target)]) | ||||
|       let &shellslash = ssl_save | ||||
|     endif | ||||
|   endif | ||||
| @ -222,7 +228,7 @@ endfunction | ||||
| " show_errors opens a location list and shows the given errors. If the given | ||||
| " errors is empty, it closes the the location list | ||||
| function! s:show_errors(errors) abort | ||||
|   let l:listtype = "locationlist" | ||||
|   let l:listtype = go#list#Type("locationlist") | ||||
|   if !empty(a:errors) | ||||
|     call go#list#Populate(l:listtype, a:errors, 'Format') | ||||
|     echohl Error | echomsg "Gofmt returned error" | echohl None | ||||
|  | ||||
| @ -29,3 +29,19 @@ func Test_update_file() | ||||
|  | ||||
|   call assert_equal(expected, actual) | ||||
| endfunc | ||||
|  | ||||
| func Test_goimports() | ||||
|   let $GOPATH = 'test-fixtures/fmt/' | ||||
|   let actual_file = tempname() | ||||
|   call writefile(readfile("test-fixtures/fmt/src/imports/goimports.go"), actual_file) | ||||
|  | ||||
|   let expected = join(readfile("test-fixtures/fmt/src/imports/goimports_golden.go"), "\n") | ||||
|  | ||||
|   " run our code | ||||
|   call go#fmt#run("goimports", actual_file, "test-fixtures/fmt/src/imports/goimports.go") | ||||
|  | ||||
|   " this should now contain the formatted code | ||||
|   let actual = join(readfile(actual_file), "\n") | ||||
|  | ||||
|   call assert_equal(expected, actual) | ||||
| endfunc | ||||
|  | ||||
| @ -16,8 +16,7 @@ function! s:guru_cmd(args) range abort | ||||
|   let selected = a:args.selected | ||||
|  | ||||
|   let result = {} | ||||
|   let dirname = expand('%:p:h') | ||||
|   let pkg = go#package#ImportPath(dirname) | ||||
|   let pkg = go#package#ImportPath() | ||||
|  | ||||
|   " this is important, check it! | ||||
|   if pkg == -1 && needs_scope | ||||
|  | ||||
| @ -71,12 +71,12 @@ endif | ||||
|  | ||||
| function! s:root_dirs() abort | ||||
|   let dirs = [] | ||||
|   let root = go#util#goroot() | ||||
|   let root = go#util#env("goroot") | ||||
|   if root !=# '' && isdirectory(root) | ||||
|     call add(dirs, root) | ||||
|   endif | ||||
|  | ||||
|   let paths = map(split(go#util#gopath(), go#util#PathListSep()), "substitute(v:val, '\\\\', '/', 'g')") | ||||
|   let paths = map(split(go#util#env("gopath"), go#util#PathListSep()), "substitute(v:val, '\\\\', '/', 'g')") | ||||
|   if go#util#ShellError() | ||||
|     return [] | ||||
|   endif | ||||
|  | ||||
| @ -52,7 +52,7 @@ function! s:spawn(bang, desc, args) abort | ||||
|         \ 'desc': a:desc, | ||||
|         \ 'bang': a:bang, | ||||
|         \ 'winnr': winnr(), | ||||
|         \ 'importpath': go#package#ImportPath(expand('%:p:h')), | ||||
|         \ 'importpath': go#package#ImportPath(), | ||||
|         \ 'state': "RUNNING", | ||||
|         \ 'stderr' : [], | ||||
|         \ 'stdout' : [], | ||||
|  | ||||
| @ -171,13 +171,13 @@ endfunction | ||||
| " the location list | ||||
| function! go#lint#Errcheck(...) abort | ||||
|   if a:0 == 0 | ||||
|     let goargs = go#package#ImportPath(expand('%:p:h')) | ||||
|     if goargs == -1 | ||||
|     let import_path = go#package#ImportPath() | ||||
|     if import_path == -1 | ||||
|       echohl Error | echomsg "vim-go: package is not inside GOPATH src" | echohl None | ||||
|       return | ||||
|     endif | ||||
|   else | ||||
|     let goargs = go#util#Shelljoin(a:000) | ||||
|     let import_path = go#util#Shelljoin(a:000) | ||||
|   endif | ||||
|  | ||||
|   let bin_path = go#path#CheckBinPath(g:go_errcheck_bin) | ||||
| @ -188,7 +188,7 @@ function! go#lint#Errcheck(...) abort | ||||
|   echon "vim-go: " | echohl Identifier | echon "errcheck analysing ..." | echohl None | ||||
|   redraw | ||||
|  | ||||
|   let command = bin_path . ' -abspath ' . goargs | ||||
|   let command = bin_path . ' -abspath ' . import_path | ||||
|   let out = go#tool#ExecuteInDir(command) | ||||
|  | ||||
|   let l:listtype = "quickfix" | ||||
| @ -199,7 +199,6 @@ function! go#lint#Errcheck(...) abort | ||||
|     call go#list#ParseFormat(l:listtype, errformat, split(out, "\n"), 'Errcheck') | ||||
|  | ||||
|     let errors = go#list#Get(l:listtype) | ||||
|  | ||||
|     if empty(errors) | ||||
|       echohl Error | echomsg "GoErrCheck returned error" | echohl None | ||||
|       echo out | ||||
| @ -207,6 +206,7 @@ function! go#lint#Errcheck(...) abort | ||||
|     endif | ||||
|  | ||||
|     if !empty(errors) | ||||
|       echohl Error | echomsg "GoErrCheck found errors" | echohl None | ||||
|       call go#list#Populate(l:listtype, errors, 'Errcheck') | ||||
|       call go#list#Window(l:listtype, len(errors)) | ||||
|       if !empty(errors) | ||||
| @ -251,16 +251,20 @@ function s:lint_job(args) | ||||
|   function! s:callback(chan, msg) closure | ||||
|     let old_errorformat = &errorformat | ||||
|     let &errorformat = l:errformat | ||||
|     caddexpr a:msg | ||||
|     if l:listtype == "locationlist" | ||||
|       lad a:msg | ||||
|     elseif l:listtype == "quickfix" | ||||
|       caddexpr a:msg | ||||
|     endif | ||||
|     let &errorformat = old_errorformat | ||||
|  | ||||
|     " TODO(jinleileiking): give a configure to jump or not | ||||
|     let l:winnr = winnr() | ||||
|  | ||||
|     copen | ||||
|     let errors = go#list#Get(l:listtype) | ||||
|     call go#list#Window(l:listtype, len(errors)) | ||||
|  | ||||
|     exe l:winnr . "wincmd w" | ||||
|  | ||||
|   endfunction | ||||
|  | ||||
|   function! s:exit_cb(job, exitval) closure | ||||
|  | ||||
| @ -68,7 +68,7 @@ function! go#list#PopulateWin(winnr, items) abort | ||||
|   call setloclist(a:winnr, a:items, 'r') | ||||
| endfunction | ||||
|  | ||||
| " Parse parses the given items based on the specified errorformat nad | ||||
| " Parse parses the given items based on the specified errorformat and | ||||
| " populates the location list. | ||||
| function! go#list#ParseFormat(listtype, errformat, items, title) abort | ||||
|   let l:listtype = go#list#Type(a:listtype) | ||||
|  | ||||
| @ -33,7 +33,7 @@ function! go#package#Paths() abort | ||||
|  | ||||
|   if !exists("s:goroot") | ||||
|     if executable('go') | ||||
|       let s:goroot = go#util#goroot() | ||||
|       let s:goroot = go#util#env("goroot") | ||||
|       if go#util#ShellError() != 0 | ||||
|         echomsg '''go env GOROOT'' failed' | ||||
|       endif | ||||
| @ -54,29 +54,25 @@ function! go#package#Paths() abort | ||||
|   return dirs | ||||
| endfunction | ||||
|  | ||||
| function! go#package#ImportPath(arg) abort | ||||
|   let path = fnamemodify(resolve(a:arg), ':p') | ||||
|   let dirs = go#package#Paths() | ||||
|  | ||||
|   for dir in dirs | ||||
|     if len(dir) && matchstr(escape(path, '\/'), escape(dir, '\/')) == 0 | ||||
|       let workspace = dir | ||||
|     endif | ||||
|   endfor | ||||
|  | ||||
|   if !exists('workspace') | ||||
| " ImportPath returns the import path in the current directory it was executed | ||||
| function! go#package#ImportPath() abort | ||||
|   let out = go#tool#ExecuteInDir("go list") | ||||
|   if go#util#ShellError() != 0 | ||||
|     return -1 | ||||
|   endif | ||||
|  | ||||
|   if go#util#IsWin() | ||||
|     let srcdir = substitute(workspace . '\src\', '//', '/', '') | ||||
|     return path[len(srcdir):] | ||||
|   else | ||||
|     let srcdir = substitute(workspace . '/src/', '//', '/', '') | ||||
|     return substitute(path, srcdir, '', '') | ||||
|   let import_path = split(out, '\n')[0] | ||||
|  | ||||
|   " go list returns '_CURRENTDIRECTORY' if the directory is not inside GOPATH. | ||||
|   " Check it and retun an error if that is the case | ||||
|   if import_path[0] ==# '_' | ||||
|     return -1 | ||||
|   endif | ||||
|  | ||||
|   return import_path | ||||
| endfunction | ||||
|  | ||||
|  | ||||
| function! go#package#FromPath(arg) abort | ||||
|   let path = fnamemodify(resolve(a:arg), ':p') | ||||
|   let dirs = go#package#Paths() | ||||
|  | ||||
| @ -39,7 +39,7 @@ endfunction | ||||
| function! go#path#Default() abort | ||||
|   if $GOPATH == "" | ||||
|     " use default GOPATH via go env | ||||
|     return go#util#gopath() | ||||
|     return go#util#env("gopath") | ||||
|   endif | ||||
|  | ||||
|   return $GOPATH | ||||
| @ -173,6 +173,17 @@ function! go#path#CheckBinPath(binpath) abort | ||||
|  | ||||
|   let $PATH = old_path | ||||
|  | ||||
|    " When you are using: | ||||
|    " 1) Windows system | ||||
|    " 2) Has cygpath executable | ||||
|    " 3) Use *sh* as 'shell' | ||||
|    " | ||||
|    " This converts your <path> to $(cygpath '<path>') to make cygwin working in | ||||
|    " shell of cygwin way | ||||
|    if go#util#IsWin() && executable('cygpath') && &shell !~ '.*sh.*' | ||||
|      return printf("$(cygpath '%s')", a:bin_path) | ||||
|    endif | ||||
|  | ||||
|   return go_bin_path . go#util#PathSep() . basename | ||||
| endfunction | ||||
|  | ||||
|  | ||||
| @ -20,7 +20,7 @@ function! go#play#Share(count, line1, line2) abort | ||||
|   call delete(share_file) | ||||
|  | ||||
|   if go#util#ShellError() != 0 | ||||
|     echo 'A error has occured. Run this command to see what the problem is:' | ||||
|     echo 'A error has occurred. Run this command to see what the problem is:' | ||||
|     echo command | ||||
|     return | ||||
|   endif | ||||
|  | ||||
| @ -53,9 +53,9 @@ function! go#statusline#Show() abort | ||||
|  | ||||
|   " only update highlight if status has changed. | ||||
|   if status_text != s:last_status | ||||
|     if status.state =~ "success" || status.state =~ "finished" | ||||
|     if status.state =~ "success" || status.state =~ "finished" || status.state =~ "pass" | ||||
|       hi goStatusLineColor cterm=bold ctermbg=76 ctermfg=22 | ||||
|     elseif status.state =~ "started" || status.state =~ "analysing" | ||||
|     elseif status.state =~ "started" || status.state =~ "analysing" || status.state =~ "compiling" | ||||
|       hi goStatusLineColor cterm=bold ctermbg=208 ctermfg=88 | ||||
|     elseif status.state =~ "failed" | ||||
|       hi goStatusLineColor cterm=bold ctermbg=196 ctermfg=52 | ||||
|  | ||||
| @ -14,21 +14,24 @@ function! go#template#create() abort | ||||
|   " files) from the directory create the template or use the cwd | ||||
|   " as the name | ||||
|   if l:package_name == -1 && l:go_template_use_pkg != 1 | ||||
|     let l:template_file = get(g:, 'go_template_file', "hello_world.go") | ||||
|     let l:filename = fnamemodify(expand("%"), ':t') | ||||
|     if l:filename =~ "_test.go$" | ||||
|       let l:template_file = get(g:, 'go_template_test_file', "hello_world_test.go") | ||||
|     else | ||||
|       let l:template_file = get(g:, 'go_template_file', "hello_world.go") | ||||
|     endif | ||||
|     let l:template_path = go#util#Join(l:root_dir, "templates", l:template_file) | ||||
|     exe '0r ' . fnameescape(l:template_path) | ||||
|     $delete _ | ||||
|   elseif l:package_name == -1 && l:go_template_use_pkg == 1 | ||||
|     " cwd is now the dir of the package | ||||
|     let l:path = fnamemodify(getcwd(), ':t') | ||||
|     let l:content = printf("package %s", l:path) | ||||
|     call append(0, l:content) | ||||
|     $delete _ | ||||
|   else | ||||
|     let l:content = printf("package %s", l:package_name) | ||||
|     call append(0, l:content) | ||||
|     $delete _ | ||||
|   endif | ||||
|   $delete _ | ||||
|  | ||||
|   " Remove the '... [New File]' message line from the command line | ||||
|   echon | ||||
|  | ||||
| @ -23,6 +23,7 @@ function! go#term#newmode(bang, cmd, mode) abort | ||||
|   let $GOPATH = go#path#Detect() | ||||
|  | ||||
|   " execute go build in the files directory | ||||
|   let l:winnr = winnr() | ||||
|   let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd ' | ||||
|   let dir = getcwd() | ||||
|  | ||||
| @ -47,6 +48,10 @@ function! go#term#newmode(bang, cmd, mode) abort | ||||
|  | ||||
|   let id = termopen(a:cmd, job) | ||||
|  | ||||
|   if l:winnr !=# winnr() | ||||
|     exe l:winnr . "wincmd w" | ||||
|   endif | ||||
|  | ||||
|   execute cd . fnameescape(dir) | ||||
|  | ||||
|   " restore back GOPATH | ||||
|  | ||||
| @ -0,0 +1,13 @@ | ||||
| package main | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| ) | ||||
|  | ||||
| func Foo(log *logging.TestLogger) { | ||||
| log.Debug("vim-go") | ||||
| } | ||||
|  | ||||
| func main() { | ||||
| 		fmt.Println("vim-go") | ||||
| } | ||||
| @ -0,0 +1,15 @@ | ||||
| package main | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
|  | ||||
| 	logging "gh.com/gi/foo-logging" | ||||
| ) | ||||
|  | ||||
| func Foo(log *logging.TestLogger) { | ||||
| 	log.Debug("vim-go") | ||||
| } | ||||
|  | ||||
| func main() { | ||||
| 	fmt.Println("vim-go") | ||||
| } | ||||
							
								
								
									
										12
									
								
								sources_non_forked/vim-go/autoload/go/test-fixtures/fmt/imports/vendor/gh.com/gi/foo-logging/logger.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								sources_non_forked/vim-go/autoload/go/test-fixtures/fmt/imports/vendor/gh.com/gi/foo-logging/logger.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| package logging | ||||
|  | ||||
| import "fmt" | ||||
|  | ||||
| type TestLogger struct { | ||||
| 	Value string | ||||
| } | ||||
|  | ||||
| func (l *TestLogger) Debug(msg string) { | ||||
| 	fmt.Println(msg) | ||||
| 	fmt.Println(l.Value) | ||||
| } | ||||
| @ -0,0 +1 @@ | ||||
| ../imports/ | ||||
							
								
								
									
										287
									
								
								sources_non_forked/vim-go/autoload/go/test.vim
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										287
									
								
								sources_non_forked/vim-go/autoload/go/test.vim
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,287 @@ | ||||
| " Test runs `go test` in the current directory. If compile is true, it'll | ||||
| " compile the tests instead of running them (useful to catch errors in the | ||||
| " test files). Any other argument is appendend to the final `go test` command | ||||
| function! go#test#Test(bang, compile, ...) abort | ||||
|   let args = ["test"] | ||||
|  | ||||
|   " don't run the test, only compile it. Useful to capture and fix errors. | ||||
|   if a:compile | ||||
|     " we're going to tell to run a test function that doesn't exist. This | ||||
|     " triggers a build of the test file itself but no tests will run. | ||||
|     call extend(args, ["-run", "499EE4A2-5C85-4D35-98FC-7377CD87F263"]) | ||||
|   endif | ||||
|  | ||||
|   if a:0 | ||||
|     let goargs = a:000 | ||||
|  | ||||
|     " do not expand for coverage mode as we're passing the arg ourself | ||||
|     if a:1 != '-coverprofile' | ||||
|       " expand all wildcards(i.e: '%' to the current file name) | ||||
|       let goargs = map(copy(a:000), "expand(v:val)") | ||||
|     endif | ||||
|  | ||||
|     if !(has('nvim') || go#util#has_job()) | ||||
|       let goargs = go#util#Shelllist(goargs, 1) | ||||
|     endif | ||||
|  | ||||
|     call extend(args, goargs, 1) | ||||
|   else | ||||
|     " only add this if no custom flags are passed | ||||
|     let timeout  = get(g:, 'go_test_timeout', '10s') | ||||
|     call add(args, printf("-timeout=%s", timeout)) | ||||
|   endif | ||||
|  | ||||
|   if get(g:, 'go_echo_command_info', 1) | ||||
|     if a:compile | ||||
|       echon "vim-go: " | echohl Identifier | echon "compiling tests ..." | echohl None | ||||
|     else | ||||
|       echon "vim-go: " | echohl Identifier | echon "testing ..." | echohl None | ||||
|     endif | ||||
|   endif | ||||
|  | ||||
|   if go#util#has_job() | ||||
|     " use vim's job functionality to call it asynchronously | ||||
|     let job_args = { | ||||
|           \ 'cmd': ['go'] + args, | ||||
|           \ 'bang': a:bang, | ||||
|           \ 'winnr': winnr(), | ||||
|           \ 'dir': getcwd(), | ||||
|           \ 'compile_test': a:compile, | ||||
|           \ 'jobdir': fnameescape(expand("%:p:h")), | ||||
|           \ } | ||||
|  | ||||
|     call s:test_job(job_args) | ||||
|     return | ||||
|   elseif has('nvim') | ||||
|     " use nvims's job functionality | ||||
|     if get(g:, 'go_term_enabled', 0) | ||||
|       let id = go#term#new(a:bang, ["go"] + args) | ||||
|     else | ||||
|       let id = go#jobcontrol#Spawn(a:bang, "test", args) | ||||
|     endif | ||||
|  | ||||
|     return id | ||||
|   endif | ||||
|  | ||||
|   call go#cmd#autowrite() | ||||
|   redraw | ||||
|  | ||||
|   let command = "go " . join(args, ' ') | ||||
|   let out = go#tool#ExecuteInDir(command) | ||||
|  | ||||
|   let l:listtype = "quickfix" | ||||
|  | ||||
|   let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd ' | ||||
|   let dir = getcwd() | ||||
|   execute cd fnameescape(expand("%:p:h")) | ||||
|  | ||||
|   if go#util#ShellError() != 0 | ||||
|     let errors = s:parse_errors(split(out, '\n')) | ||||
|     let errors = go#tool#FilterValids(errors) | ||||
|  | ||||
|     call go#list#Populate(l:listtype, errors, command) | ||||
|     call go#list#Window(l:listtype, len(errors)) | ||||
|     if !empty(errors) && !a:bang | ||||
|       call go#list#JumpToFirst(l:listtype) | ||||
|     elseif empty(errors) | ||||
|       " failed to parse errors, output the original content | ||||
|       call go#util#EchoError(out) | ||||
|     endif | ||||
|     echon "vim-go: " | echohl ErrorMsg | echon "[test] FAIL" | echohl None | ||||
|   else | ||||
|     call go#list#Clean(l:listtype) | ||||
|     call go#list#Window(l:listtype) | ||||
|  | ||||
|     if a:compile | ||||
|       echon "vim-go: " | echohl Function | echon "[test] SUCCESS" | echohl None | ||||
|     else | ||||
|       echon "vim-go: " | echohl Function | echon "[test] PASS" | echohl None | ||||
|     endif | ||||
|   endif | ||||
|   execute cd . fnameescape(dir) | ||||
| endfunction | ||||
|  | ||||
| " Testfunc runs a single test that surrounds the current cursor position. | ||||
| " Arguments are passed to the `go test` command. | ||||
| function! go#test#Func(bang, ...) abort | ||||
|   " search flags legend (used only) | ||||
|   " 'b' search backward instead of forward | ||||
|   " 'c' accept a match at the cursor position | ||||
|   " 'n' do Not move the cursor | ||||
|   " 'W' don't wrap around the end of the file | ||||
|   " | ||||
|   " for the full list | ||||
|   " :help search | ||||
|   let test = search('func \(Test\|Example\)', "bcnW") | ||||
|  | ||||
|   if test == 0 | ||||
|     echo "vim-go: [test] no test found immediate to cursor" | ||||
|     return | ||||
|   end | ||||
|  | ||||
|   let line = getline(test) | ||||
|   let name = split(split(line, " ")[1], "(")[0] | ||||
|   let args = [a:bang, 0, "-run", name . "$"] | ||||
|  | ||||
|   if a:0 | ||||
|     call extend(args, a:000) | ||||
|   endif | ||||
|  | ||||
|   call call('go#test#Test', args) | ||||
| endfunction | ||||
|  | ||||
| function s:test_job(args) abort | ||||
|   let status_dir = expand('%:p:h') | ||||
|   let started_at = reltime() | ||||
|  | ||||
|   let status = { | ||||
|         \ 'desc': 'current status', | ||||
|         \ 'type': "test", | ||||
|         \ 'state': "started", | ||||
|         \ } | ||||
|  | ||||
|   if a:args.compile_test | ||||
|     let status.state = "compiling" | ||||
|   endif | ||||
|  | ||||
|   call go#statusline#Update(status_dir, status) | ||||
|  | ||||
|   " autowrite is not enabled for jobs | ||||
|   call go#cmd#autowrite() | ||||
|  | ||||
|   let messages = [] | ||||
|   function! s:callback(chan, msg) closure | ||||
|     call add(messages, a:msg) | ||||
|   endfunction | ||||
|  | ||||
|   function! s:exit_cb(job, exitval) closure | ||||
|     let status = { | ||||
|           \ 'desc': 'last status', | ||||
|           \ 'type': "test", | ||||
|           \ 'state': "pass", | ||||
|           \ } | ||||
|  | ||||
|     if a:args.compile_test | ||||
|       let status.state = "success" | ||||
|     endif | ||||
|  | ||||
|     if a:exitval | ||||
|       let status.state = "failed" | ||||
|     endif | ||||
|  | ||||
|     if get(g:, 'go_echo_command_info', 1) | ||||
|       if a:exitval == 0 | ||||
|         if a:args.compile_test | ||||
|           call go#util#EchoSuccess("SUCCESS") | ||||
|         else | ||||
|           call go#util#EchoSuccess("PASS") | ||||
|         endif | ||||
|       else | ||||
|         call go#util#EchoError("FAILED") | ||||
|       endif | ||||
|     endif | ||||
|  | ||||
|     let elapsed_time = reltimestr(reltime(started_at)) | ||||
|     " strip whitespace | ||||
|     let elapsed_time = substitute(elapsed_time, '^\s*\(.\{-}\)\s*$', '\1', '') | ||||
|     let status.state .= printf(" (%ss)", elapsed_time) | ||||
|  | ||||
|     call go#statusline#Update(status_dir, status) | ||||
|  | ||||
|     let l:listtype = go#list#Type("quickfix") | ||||
|     if a:exitval == 0 | ||||
|       call go#list#Clean(l:listtype) | ||||
|       call go#list#Window(l:listtype) | ||||
|       return | ||||
|     endif | ||||
|  | ||||
|     call s:show_errors(a:args, a:exitval, messages) | ||||
|   endfunction | ||||
|  | ||||
|   let start_options = { | ||||
|         \ 'callback': funcref("s:callback"), | ||||
|         \ 'exit_cb': funcref("s:exit_cb"), | ||||
|         \ } | ||||
|  | ||||
|   " modify GOPATH if needed | ||||
|   let old_gopath = $GOPATH | ||||
|   let $GOPATH = go#path#Detect() | ||||
|  | ||||
|   " pre start | ||||
|   let dir = getcwd() | ||||
|   let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd ' | ||||
|   let jobdir = fnameescape(expand("%:p:h")) | ||||
|   execute cd . jobdir | ||||
|  | ||||
|   call job_start(a:args.cmd, start_options) | ||||
|  | ||||
|   " post start | ||||
|   execute cd . fnameescape(dir) | ||||
|   let $GOPATH = old_gopath | ||||
| endfunction | ||||
|  | ||||
| " show_errors parses the given list of lines of a 'go test' output and returns | ||||
| " a quickfix compatible list of errors. It's intended to be used only for go | ||||
| " test output.  | ||||
| function! s:show_errors(args, exit_val, messages) abort | ||||
|   let l:listtype = go#list#Type("quickfix") | ||||
|  | ||||
|   let cd = exists('*haslocaldir') && haslocaldir() ? 'lcd ' : 'cd ' | ||||
|   try | ||||
|     execute cd a:args.jobdir | ||||
|     let errors = s:parse_errors(a:messages) | ||||
|     let errors = go#tool#FilterValids(errors) | ||||
|   finally | ||||
|     execute cd . fnameescape(a:args.dir) | ||||
|   endtry | ||||
|  | ||||
|   if !len(errors) | ||||
|     " failed to parse errors, output the original content | ||||
|     call go#util#EchoError(join(a:messages, " ")) | ||||
|     call go#util#EchoError(a:args.dir) | ||||
|     return | ||||
|   endif | ||||
|  | ||||
|   if a:args.winnr == winnr() | ||||
|     call go#list#Populate(l:listtype, errors, join(a:args.cmd)) | ||||
|     call go#list#Window(l:listtype, len(errors)) | ||||
|     if !empty(errors) && !a:args.bang | ||||
|       call go#list#JumpToFirst(l:listtype) | ||||
|     endif | ||||
|   endif | ||||
| endfunction | ||||
|  | ||||
| function! s:parse_errors(lines) abort | ||||
|   let errors = [] | ||||
|  | ||||
|   " NOTE(arslan): once we get JSON output everything will be easier :) | ||||
|   " https://github.com/golang/go/issues/2981 | ||||
|   for line in a:lines | ||||
|     let fatalerrors = matchlist(line, '^\(fatal error:.*\)$') | ||||
|     let tokens = matchlist(line, '^\s*\(.\{-}\.go\):\(\d\+\):\s*\(.*\)') | ||||
|  | ||||
|     if !empty(fatalerrors) | ||||
|       call add(errors, {"text": fatalerrors[1]}) | ||||
|     elseif !empty(tokens) | ||||
|       " strip endlines of form ^M | ||||
|       let out = substitute(tokens[3], '\r$', '', '') | ||||
|  | ||||
|       call add(errors, { | ||||
|             \ "filename" : fnamemodify(tokens[1], ':p'), | ||||
|             \ "lnum"     : tokens[2], | ||||
|             \ "text"     : out, | ||||
|             \ }) | ||||
|     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 errors | ||||
| endfunction | ||||
|  | ||||
| " vim: sw=2 ts=2 et | ||||
| " | ||||
| @ -74,24 +74,32 @@ function! go#util#env(key) abort | ||||
|   return l:var | ||||
| endfunction | ||||
|  | ||||
| " goarch returns 'go env GOARCH'. This is an internal function and shouldn't | ||||
| " be used. Instead use 'go#util#env("goarch")' | ||||
| function! go#util#goarch() abort | ||||
|   return substitute(go#util#System('go env GOARCH'), '\n', '', 'g') | ||||
| endfunction | ||||
|  | ||||
| " goos returns 'go env GOOS'. This is an internal function and shouldn't | ||||
| " be used. Instead use 'go#util#env("goos")' | ||||
| function! go#util#goos() abort | ||||
|   return substitute(go#util#System('go env GOOS'), '\n', '', 'g') | ||||
| endfunction | ||||
|  | ||||
| " goroot returns 'go env GOROOT'. This is an internal function and shouldn't | ||||
| " be used. Instead use 'go#util#env("goroot")' | ||||
| function! go#util#goroot() abort | ||||
|   return substitute(go#util#System('go env GOROOT'), '\n', '', 'g') | ||||
| endfunction | ||||
|  | ||||
| " gopath returns 'go env GOPATH'. This is an internal function and shouldn't | ||||
| " be used. Instead use 'go#util#env("gopath")' | ||||
| function! go#util#gopath() abort | ||||
|   return substitute(go#util#System('go env GOPATH'), '\n', '', 'g') | ||||
| endfunction | ||||
|  | ||||
| function! go#util#osarch() abort | ||||
|   return go#util#goos() . '_' . go#util#goarch() | ||||
|   return go#util#env("goos") . '_' . go#util#env("goarch") | ||||
| endfunction | ||||
|  | ||||
| " System runs a shell command. If possible, it will temporary set  | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 amix
					amix