Added option for gometalinter to lint package (#1156)

* Added option for `gometalinter` to lint package
* added tests for the `gometalinter` command
* changed gometalinter commands to use BufferCdString
This commit is contained in:
Jeff Willette 2017-12-05 03:42:36 +09:00 committed by w0rp
parent 159733c459
commit e2a8f759d8
3 changed files with 49 additions and 20 deletions

View File

@ -1,8 +1,9 @@
" Author: Ben Reedy <https://github.com/breed808> " Author: Ben Reedy <https://github.com/breed808>, Jeff Willette <jrwillette88@gmail.com>
" Description: Adds support for the gometalinter suite for Go files " Description: Adds support for the gometalinter suite for Go files
call ale#Set('go_gometalinter_options', '') call ale#Set('go_gometalinter_options', '')
call ale#Set('go_gometalinter_executable', 'gometalinter') call ale#Set('go_gometalinter_executable', 'gometalinter')
call ale#Set('go_gometalinter_lint_package', 0)
function! ale_linters#go#gometalinter#GetExecutable(buffer) abort function! ale_linters#go#gometalinter#GetExecutable(buffer) abort
return ale#Var(a:buffer, 'go_gometalinter_executable') return ale#Var(a:buffer, 'go_gometalinter_executable')
@ -10,13 +11,22 @@ endfunction
function! ale_linters#go#gometalinter#GetCommand(buffer) abort function! ale_linters#go#gometalinter#GetCommand(buffer) abort
let l:executable = ale_linters#go#gometalinter#GetExecutable(a:buffer) let l:executable = ale_linters#go#gometalinter#GetExecutable(a:buffer)
let l:filename = expand('#' . a:buffer) let l:filename = expand('#' . a:buffer . ':t')
let l:options = ale#Var(a:buffer, 'go_gometalinter_options') let l:options = ale#Var(a:buffer, 'go_gometalinter_options')
let l:lint_package = ale#Var(a:buffer, 'go_gometalinter_lint_package')
return ale#Escape(l:executable) " BufferCdString is used so that we can be sure the paths output from gometalinter can
\ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(l:filename)) " be calculated to absolute paths in the Handler
\ . (!empty(l:options) ? ' ' . l:options : '') if l:lint_package
\ . ' ' . ale#Escape(fnamemodify(l:filename, ':h')) return ale#path#BufferCdString(a:buffer)
\ . ale#Escape(l:executable)
\ . (!empty(l:options) ? ' ' . l:options : '') . ' .'
endif
return ale#path#BufferCdString(a:buffer)
\ . ale#Escape(l:executable)
\ . ' --include=' . ale#Escape(ale#util#EscapePCRE(l:filename))
\ . (!empty(l:options) ? ' ' . l:options : '') . ' .'
endfunction endfunction
function! ale_linters#go#gometalinter#GetMatches(lines) abort function! ale_linters#go#gometalinter#GetMatches(lines) abort
@ -26,10 +36,13 @@ function! ale_linters#go#gometalinter#GetMatches(lines) abort
endfunction endfunction
function! ale_linters#go#gometalinter#Handler(buffer, lines) abort function! ale_linters#go#gometalinter#Handler(buffer, lines) abort
let l:dir = expand('#' . a:buffer . ':p:h')
let l:output = [] let l:output = []
for l:match in ale_linters#go#gometalinter#GetMatches(a:lines) for l:match in ale_linters#go#gometalinter#GetMatches(a:lines)
" l:match[1] will already be an absolute path, output from gometalinter
call add(l:output, { call add(l:output, {
\ 'filename': ale#path#GetAbsPath(l:dir, l:match[1]),
\ 'lnum': l:match[2] + 0, \ 'lnum': l:match[2] + 0,
\ 'col': l:match[3] + 0, \ 'col': l:match[3] + 0,
\ 'type': tolower(l:match[4]) is# 'warning' ? 'W' : 'E', \ 'type': tolower(l:match[4]) is# 'warning' ? 'W' : 'E',

View File

@ -1,9 +1,11 @@
Before: Before:
Save b:ale_go_gometalinter_executable Save b:ale_go_gometalinter_executable
Save b:ale_go_gometalinter_options Save b:ale_go_gometalinter_options
Save b:ale_go_gometalinter_lint_package
let b:ale_go_gometalinter_executable = 'gometalinter' let b:ale_go_gometalinter_executable = 'gometalinter'
let b:ale_go_gometalinter_options = '' let b:ale_go_gometalinter_options = ''
let b:ale_go_gometalinter_lint_package = 0
runtime ale_linters/go/gometalinter.vim runtime ale_linters/go/gometalinter.vim
@ -21,9 +23,10 @@ Execute(The gometalinter callback should return the right defaults):
\ 'gometalinter', \ 'gometalinter',
\ ale_linters#go#gometalinter#GetExecutable(bufnr('')) \ ale_linters#go#gometalinter#GetExecutable(bufnr(''))
AssertEqual AssertEqual
\ ale#Escape('gometalinter') \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
\ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(expand('%'))) \ . ale#Escape('gometalinter')
\ . ' ' . ale#Escape(getcwd()), \ . ' --include=' . ale#Escape(ale#util#EscapePCRE(expand('%' . ':t')))
\ . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr('')) \ ale_linters#go#gometalinter#GetCommand(bufnr(''))
Execute(The gometalinter callback should use a configured executable): Execute(The gometalinter callback should use a configured executable):
@ -33,17 +36,26 @@ Execute(The gometalinter callback should use a configured executable):
\ 'something else', \ 'something else',
\ ale_linters#go#gometalinter#GetExecutable(bufnr('')) \ ale_linters#go#gometalinter#GetExecutable(bufnr(''))
AssertEqual AssertEqual
\ ale#Escape('something else') \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
\ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(expand('%'))) \ . ale#Escape('something else')
\ . ' ' . ale#Escape(getcwd()), \ . ' --include=' . ale#Escape(ale#util#EscapePCRE(expand('%' . ':t')))
\ . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr('')) \ ale_linters#go#gometalinter#GetCommand(bufnr(''))
Execute(The gometalinter callback should use configured options): Execute(The gometalinter callback should use configured options):
let b:ale_go_gometalinter_options = '--foobar' let b:ale_go_gometalinter_options = '--foobar'
AssertEqual AssertEqual
\ ale#Escape('gometalinter') \ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
\ . ' --include=' . ale#Escape('^' . ale#util#EscapePCRE(expand('%'))) \ . ale#Escape('gometalinter')
\ . ' --foobar' \ . ' --include=' . ale#Escape(ale#util#EscapePCRE(expand('%' . ':t')))
\ . ' ' . ale#Escape(getcwd()), \ . ' --foobar' . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr(''))
Execute(The gometalinter `lint_package` option should use the correct command):
let b:ale_go_gometalinter_lint_package = 1
AssertEqual
\ 'cd ' . ale#Escape(expand('%:p:h')) . ' && '
\ . ale#Escape('gometalinter') . ' .',
\ ale_linters#go#gometalinter#GetCommand(bufnr('')) \ ale_linters#go#gometalinter#GetCommand(bufnr(''))

View File

@ -29,8 +29,10 @@ Execute (The gometalinter handler should handle names with spaces):
\ 'C:\something\file with spaces.go:37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)', \ 'C:\something\file with spaces.go:37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)',
\ ]), 'v:val[1:5]') \ ]), 'v:val[1:5]')
Execute (The gometalinter handler should handle relative paths correctly): Execute (The gometalinter handler should handle paths correctly):
silent file /foo/bar/baz.go call ale#test#SetFilename('app/test.go')
let file = ale#path#GetAbsPath(expand('%:p:h'), 'test.go')
AssertEqual AssertEqual
\ [ \ [
@ -39,15 +41,17 @@ Execute (The gometalinter handler should handle relative paths correctly):
\ 'col': 3, \ 'col': 3,
\ 'text': 'expected ''package'', found ''IDENT'' gibberish (staticcheck)', \ 'text': 'expected ''package'', found ''IDENT'' gibberish (staticcheck)',
\ 'type': 'W', \ 'type': 'W',
\ 'filename': ale#path#Winify(expand('%:p:h') . '/test.go'),
\ }, \ },
\ { \ {
\ 'lnum': 37, \ 'lnum': 37,
\ 'col': 5, \ 'col': 5,
\ 'text': 'expected ''package'', found ''IDENT'' gibberish (golint)', \ 'text': 'expected ''package'', found ''IDENT'' gibberish (golint)',
\ 'type': 'E', \ 'type': 'E',
\ 'filename': ale#path#Winify(expand('%:p:h') . '/test.go'),
\ }, \ },
\ ], \ ],
\ ale_linters#go#gometalinter#Handler(bufnr(''), [ \ ale_linters#go#gometalinter#Handler(bufnr(''), [
\ 'baz.go:12:3:warning: expected ''package'', found ''IDENT'' gibberish (staticcheck)', \ file . ':12:3:warning: expected ''package'', found ''IDENT'' gibberish (staticcheck)',
\ 'baz.go:37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)', \ file . ':37:5:error: expected ''package'', found ''IDENT'' gibberish (golint)',
\ ]) \ ])