b9f02ffb27
- Re: f224ce8a377bbb3a0deb78b98fdc6c43555791e2 - The issues that prompted the above commit which reverted changes made to `go build` and `gometalinter` seemed to suggest that the main issue was with gometalinter and that changes should be put into different commits so they are independent of each other - This commit reinstates the changes to the `go build` linter which seem to be uncontested and it also seems absolutely necessary to show errors from all files in the package which may have caused a build failure.
69 lines
2.2 KiB
VimL
69 lines
2.2 KiB
VimL
" Author: Joshua Rubin <joshua@rubixconsulting.com>, Ben Reedy <https://github.com/breed808>,
|
|
" Jeff Willette <jrwillette88@gmail.com>
|
|
" Description: go build for Go files
|
|
|
|
" inspired by work from dzhou121 <dzhou121@gmail.com>
|
|
|
|
function! ale_linters#go#gobuild#GoEnv(buffer) abort
|
|
if exists('s:go_env')
|
|
return ''
|
|
endif
|
|
|
|
return 'go env GOPATH GOROOT'
|
|
endfunction
|
|
|
|
function! ale_linters#go#gobuild#GetCommand(buffer, goenv_output) abort
|
|
if !exists('s:go_env')
|
|
let s:go_env = {
|
|
\ 'GOPATH': a:goenv_output[0],
|
|
\ 'GOROOT': a:goenv_output[1],
|
|
\}
|
|
endif
|
|
|
|
" Run go test in local directory with relative path
|
|
return 'GOPATH=' . s:go_env.GOPATH
|
|
\ . ' cd ' . fnamemodify(bufname(a:buffer), ':.:h')
|
|
\ . ' && go test -c -o /dev/null ./'
|
|
endfunction
|
|
|
|
function! ale_linters#go#gobuild#GetMatches(lines) abort
|
|
" Matches patterns like the following:
|
|
"
|
|
" file.go:27: missing argument for Printf("%s"): format reads arg 2, have only 1 args
|
|
" file.go:53:10: if block ends with a return statement, so drop this else and outdent its block (move short variable declaration to its own line if necessary)
|
|
" file.go:5:2: expected declaration, found 'STRING' "log"
|
|
|
|
" go test returns relative paths so use tail of filename as part of pattern matcher
|
|
let l:pattern = '\v^([a-zA-Z]?:?[^:]+):(\d+):?(\d+)?:? (.+)$'
|
|
|
|
return ale#util#GetMatches(a:lines, l:pattern)
|
|
endfunction
|
|
|
|
function! ale_linters#go#gobuild#Handler(buffer, lines) abort
|
|
let l:dir = expand('#' . a:buffer . ':p:h')
|
|
let l:output = []
|
|
|
|
for l:match in ale_linters#go#gobuild#GetMatches(a:lines)
|
|
call add(l:output, {
|
|
\ 'filename': ale#path#GetAbsPath(l:dir, l:match[1]),
|
|
\ 'lnum': l:match[2] + 0,
|
|
\ 'col': l:match[3] + 0,
|
|
\ 'text': l:match[4],
|
|
\ 'type': 'E',
|
|
\})
|
|
endfor
|
|
|
|
return l:output
|
|
endfunction
|
|
|
|
call ale#linter#Define('go', {
|
|
\ 'name': 'go build',
|
|
\ 'executable': 'go',
|
|
\ 'command_chain': [
|
|
\ {'callback': 'ale_linters#go#gobuild#GoEnv', 'output_stream': 'stdout'},
|
|
\ {'callback': 'ale_linters#go#gobuild#GetCommand', 'output_stream': 'stderr'},
|
|
\ ],
|
|
\ 'callback': 'ale_linters#go#gobuild#Handler',
|
|
\ 'lint_file': 1,
|
|
\})
|