Replace every stdin-wrapper script with the new %t formatting support
This commit is contained in:
parent
c33602534e
commit
ecbb276805
@ -4,6 +4,6 @@
|
|||||||
call ale#linter#Define('ansible', {
|
call ale#linter#Define('ansible', {
|
||||||
\ 'name': 'ansible',
|
\ 'name': 'ansible',
|
||||||
\ 'executable': 'ansible',
|
\ 'executable': 'ansible',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .yml ansible-lint -p',
|
\ 'command': 'ansible-lint -p %t',
|
||||||
\ 'callback': 'ale#handlers#HandlePEP8Format',
|
\ 'callback': 'ale#handlers#HandlePEP8Format',
|
||||||
\})
|
\})
|
||||||
|
@ -2,15 +2,14 @@
|
|||||||
" Description: cppcheck linter for c files
|
" Description: cppcheck linter for c files
|
||||||
|
|
||||||
" Set this option to change the cppcheck options
|
" Set this option to change the cppcheck options
|
||||||
if !exists('g:ale_c_cppcheck_options')
|
let g:ale_c_cppcheck_options = get(g:, 'ale_c_cppcheck_options', '--enable=style')
|
||||||
let g:ale_c_cppcheck_options = '--enable=style'
|
|
||||||
endif
|
|
||||||
|
|
||||||
call ale#linter#Define('c', {
|
call ale#linter#Define('c', {
|
||||||
\ 'name': 'cppcheck',
|
\ 'name': 'cppcheck',
|
||||||
\ 'output_stream': 'both',
|
\ 'output_stream': 'both',
|
||||||
\ 'executable': 'cppcheck',
|
\ 'executable': 'cppcheck',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .c cppcheck -q --language=c '
|
\ 'command': 'cppcheck -q --language=c '
|
||||||
\ . g:ale_c_cppcheck_options,
|
\ . g:ale_c_cppcheck_options
|
||||||
|
\ . ' %t',
|
||||||
\ 'callback': 'ale#handlers#HandleCppCheckFormat',
|
\ 'callback': 'ale#handlers#HandleCppCheckFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -35,7 +35,7 @@ endfunction
|
|||||||
call ale#linter#Define('chef', {
|
call ale#linter#Define('chef', {
|
||||||
\ 'name': 'foodcritic',
|
\ 'name': 'foodcritic',
|
||||||
\ 'executable': 'foodcritic',
|
\ 'executable': 'foodcritic',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .rb foodcritic',
|
\ 'command': 'foodcritic %t',
|
||||||
\ 'callback': 'ale_linters#chef#foodcritic#Handle',
|
\ 'callback': 'ale_linters#chef#foodcritic#Handle',
|
||||||
\})
|
\})
|
||||||
|
|
||||||
|
@ -2,15 +2,14 @@
|
|||||||
" Description: cppcheck linter for cpp files
|
" Description: cppcheck linter for cpp files
|
||||||
|
|
||||||
" Set this option to change the cppcheck options
|
" Set this option to change the cppcheck options
|
||||||
if !exists('g:ale_cpp_cppcheck_options')
|
let g:ale_cpp_cppcheck_options = get(g:, 'ale_cpp_cppcheck_options', '--enable=style')
|
||||||
let g:ale_cpp_cppcheck_options = '--enable=style'
|
|
||||||
endif
|
|
||||||
|
|
||||||
call ale#linter#Define('cpp', {
|
call ale#linter#Define('cpp', {
|
||||||
\ 'name': 'cppcheck',
|
\ 'name': 'cppcheck',
|
||||||
\ 'output_stream': 'both',
|
\ 'output_stream': 'both',
|
||||||
\ 'executable': 'cppcheck',
|
\ 'executable': 'cppcheck',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .cpp cppcheck -q --language=c++ '
|
\ 'command': 'cppcheck -q --language=c++ '
|
||||||
\ . g:ale_cpp_cppcheck_options,
|
\ . g:ale_cpp_cppcheck_options
|
||||||
|
\ . ' %t',
|
||||||
\ 'callback': 'ale#handlers#HandleCppCheckFormat',
|
\ 'callback': 'ale#handlers#HandleCppCheckFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
if !exists('g:ale_cs_mcs_options')
|
let g:ale_cs_mcs_options = get(g:, 'ale_cs_mcs_options', '')
|
||||||
let g:ale_cs_mcs_options = ''
|
|
||||||
endif
|
function! ale_linters#cs#mcs#GetCommand(buffer) abort
|
||||||
|
return 'mcs -unsafe --parse ' . g:ale_cs_mcs_options . ' %t'
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#cs#mcs#Handle(buffer, lines) abort
|
function! ale_linters#cs#mcs#Handle(buffer, lines) abort
|
||||||
" Look for lines like the following.
|
" Look for lines like the following.
|
||||||
@ -34,7 +36,6 @@ call ale#linter#Define('cs',{
|
|||||||
\ 'name': 'mcs',
|
\ 'name': 'mcs',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'mcs',
|
\ 'executable': 'mcs',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .cs mcs -unsafe --parse' . g:ale_cs_mcs_options,
|
\ 'command_callback': 'ale_linters#cs#mcs#GetCommand',
|
||||||
\ 'callback': 'ale_linters#cs#mcs#Handle',
|
\ 'callback': 'ale_linters#cs#mcs#Handle',
|
||||||
\})
|
\})
|
||||||
|
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
call ale#linter#Define('css', {
|
call ale#linter#Define('css', {
|
||||||
\ 'name': 'csslint',
|
\ 'name': 'csslint',
|
||||||
\ 'executable': 'csslint',
|
\ 'executable': 'csslint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .css csslint --format=compact',
|
\ 'command': 'csslint --format=compact %t',
|
||||||
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -46,9 +46,7 @@ function! ale_linters#d#dmd#DMDCommand(buffer, dub_output) abort
|
|||||||
endif
|
endif
|
||||||
endfor
|
endfor
|
||||||
|
|
||||||
return g:ale#util#stdin_wrapper . ' .d dmd '
|
return 'dmd '. join(l:import_list) . ' -o- -vcolumns -c %t'
|
||||||
\ . join(l:import_list)
|
|
||||||
\ . ' -o- -vcolumns -c'
|
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#d#dmd#Handle(buffer, lines) abort
|
function! ale_linters#d#dmd#Handle(buffer, lines) abort
|
||||||
|
@ -52,9 +52,8 @@ function! ale_linters#elm#make#GetCommand(buffer) abort
|
|||||||
" which is why this is hard coded here.
|
" which is why this is hard coded here.
|
||||||
" Source: https://github.com/elm-lang/elm-make/blob/master/src/Flags.hs
|
" Source: https://github.com/elm-lang/elm-make/blob/master/src/Flags.hs
|
||||||
let l:elm_cmd = 'elm-make --report=json --output='.shellescape('/dev/null')
|
let l:elm_cmd = 'elm-make --report=json --output='.shellescape('/dev/null')
|
||||||
let l:stdin_wrapper = g:ale#util#stdin_wrapper . ' .elm'
|
|
||||||
|
|
||||||
return l:dir_set_cmd . ' ' . l:stdin_wrapper . ' ' . l:elm_cmd
|
return l:dir_set_cmd . ' ' . l:elm_cmd . ' %t'
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
call ale#linter#Define('elm', {
|
call ale#linter#Define('elm', {
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
let g:ale_erlang_erlc_options = get(g:, 'ale_erlang_erlc_options', '')
|
let g:ale_erlang_erlc_options = get(g:, 'ale_erlang_erlc_options', '')
|
||||||
|
|
||||||
function! ale_linters#erlang#erlc#GetCommand(buffer) abort
|
function! ale_linters#erlang#erlc#GetCommand(buffer) abort
|
||||||
return g:ale#util#stdin_wrapper . ' .erl erlc ' . g:ale_erlang_erlc_options
|
return 'erlc ' . g:ale_erlang_erlc_options . ' %t'
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#erlang#erlc#Handle(buffer, lines) abort
|
function! ale_linters#erlang#erlc#Handle(buffer, lines) abort
|
||||||
|
@ -5,6 +5,6 @@ call ale#linter#Define('go', {
|
|||||||
\ 'name': 'gofmt',
|
\ 'name': 'gofmt',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'gofmt',
|
\ 'executable': 'gofmt',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .go gofmt -e',
|
\ 'command': 'gofmt -e %t',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
||||||
\})
|
\})
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
call ale#linter#Define('go', {
|
call ale#linter#Define('go', {
|
||||||
\ 'name': 'golint',
|
\ 'name': 'golint',
|
||||||
\ 'executable': 'golint',
|
\ 'executable': 'golint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .go golint',
|
\ 'command': 'golint %t',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
||||||
\})
|
\})
|
||||||
|
@ -5,6 +5,6 @@ call ale#linter#Define('go', {
|
|||||||
\ 'name': 'go vet',
|
\ 'name': 'go vet',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'go',
|
\ 'executable': 'go',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .go go vet',
|
\ 'command': 'go vet %t',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
||||||
\})
|
\})
|
||||||
|
@ -60,7 +60,7 @@ call ale#linter#Define('haskell', {
|
|||||||
\ 'name': 'ghc',
|
\ 'name': 'ghc',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'ghc',
|
\ 'executable': 'ghc',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .hs ghc -fno-code -v0',
|
\ 'command': 'ghc -fno-code -v0 %t',
|
||||||
\ 'callback': 'ale_linters#haskell#ghc#Handle',
|
\ 'callback': 'ale_linters#haskell#ghc#Handle',
|
||||||
\})
|
\})
|
||||||
|
|
||||||
@ -68,6 +68,6 @@ call ale#linter#Define('haskell', {
|
|||||||
\ 'name': 'stack-ghc',
|
\ 'name': 'stack-ghc',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'stack',
|
\ 'executable': 'stack',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .hs stack ghc -- -fno-code -v0',
|
\ 'command': 'stack ghc -- -fno-code -v0 %t',
|
||||||
\ 'callback': 'ale_linters#haskell#ghc#Handle',
|
\ 'callback': 'ale_linters#haskell#ghc#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -23,9 +23,9 @@ function! ale_linters#html#htmlhint#GetExecutable(buffer) abort
|
|||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#html#htmlhint#GetCommand(buffer) abort
|
function! ale_linters#html#htmlhint#GetCommand(buffer) abort
|
||||||
return g:ale#util#stdin_wrapper . ' .html '
|
return ale_linters#html#htmlhint#GetExecutable(a:buffer)
|
||||||
\ . ale_linters#html#htmlhint#GetExecutable(a:buffer)
|
|
||||||
\ . ' ' . g:ale_html_htmlhint_options
|
\ . ' ' . g:ale_html_htmlhint_options
|
||||||
|
\ . ' %t'
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
call ale#linter#Define('html', {
|
call ale#linter#Define('html', {
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
call ale#linter#Define('markdown', {
|
call ale#linter#Define('markdown', {
|
||||||
\ 'name': 'proselint',
|
\ 'name': 'proselint',
|
||||||
\ 'executable': 'proselint',
|
\ 'executable': 'proselint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .md proselint',
|
\ 'command': 'proselint %t',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
||||||
\})
|
\})
|
||||||
|
@ -4,6 +4,16 @@
|
|||||||
let g:ale_matlab_mlint_executable =
|
let g:ale_matlab_mlint_executable =
|
||||||
\ get(g:, 'ale_matlab_mlint_executable', 'mlint')
|
\ get(g:, 'ale_matlab_mlint_executable', 'mlint')
|
||||||
|
|
||||||
|
function! ale_linters#matlab#mlint#GetExecutable(buffer) abort
|
||||||
|
return g:ale_matlab_mlint_executable
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#matlab#mlint#GetCommand(buffer) abort
|
||||||
|
let l:executable = ale_linters#matlab#mlint#GetExecutable(a:buffer)
|
||||||
|
|
||||||
|
return l:executable . ' -id %t'
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#matlab#mlint#Handle(buffer, lines) abort
|
function! ale_linters#matlab#mlint#Handle(buffer, lines) abort
|
||||||
" Matches patterns like the following:
|
" Matches patterns like the following:
|
||||||
"
|
"
|
||||||
@ -47,9 +57,8 @@ endfunction
|
|||||||
|
|
||||||
call ale#linter#Define('matlab', {
|
call ale#linter#Define('matlab', {
|
||||||
\ 'name': 'mlint',
|
\ 'name': 'mlint',
|
||||||
\ 'executable': 'mlint',
|
\ 'executable_callback': 'ale_linters#matlab#mlint#GetExecutable',
|
||||||
\ 'command': g:ale#util#stdin_wrapper .
|
\ 'command_callback': 'ale_linters#matlab#mlint#GetCommand',
|
||||||
\ ' .m ' . g:ale_matlab_mlint_executable . ' -id',
|
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'callback': 'ale_linters#matlab#mlint#Handle',
|
\ 'callback': 'ale_linters#matlab#mlint#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -36,6 +36,6 @@ endfunction
|
|||||||
call ale#linter#Define('php', {
|
call ale#linter#Define('php', {
|
||||||
\ 'name': 'phpmd',
|
\ 'name': 'phpmd',
|
||||||
\ 'executable': 'phpmd',
|
\ 'executable': 'phpmd',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .php phpmd %s text ' . g:ale_php_phpmd_ruleset . ' --ignore-violations-on-exit',
|
\ 'command': 'phpmd %s text ' . g:ale_php_phpmd_ruleset . ' --ignore-violations-on-exit %t',
|
||||||
\ 'callback': 'ale_linters#php#phpmd#Handle',
|
\ 'callback': 'ale_linters#php#phpmd#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -5,6 +5,6 @@ call ale#linter#Define('pug', {
|
|||||||
\ 'name': 'puglint',
|
\ 'name': 'puglint',
|
||||||
\ 'executable': 'pug-lint',
|
\ 'executable': 'pug-lint',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .pug pug-lint -r inline',
|
\ 'command': 'pug-lint -r inline %t',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
||||||
\})
|
\})
|
||||||
|
@ -33,6 +33,6 @@ call ale#linter#Define('puppet', {
|
|||||||
\ 'name': 'puppet',
|
\ 'name': 'puppet',
|
||||||
\ 'executable': 'puppet',
|
\ 'executable': 'puppet',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .pp puppet parser validate --color=false',
|
\ 'command': 'puppet parser validate --color=false %t',
|
||||||
\ 'callback': 'ale_linters#puppet#puppet#Handle',
|
\ 'callback': 'ale_linters#puppet#puppet#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
call ale#linter#Define('puppet', {
|
call ale#linter#Define('puppet', {
|
||||||
\ 'name': 'puppetlint',
|
\ 'name': 'puppetlint',
|
||||||
\ 'executable': 'puppet-lint',
|
\ 'executable': 'puppet-lint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .pp puppet-lint --no-autoloader_layout-check --log-format "-:%{line}:%{column}: %{kind}: [%{check}] %{message}"',
|
\ 'command': 'puppet-lint --no-autoloader_layout-check'
|
||||||
|
\ . ' --log-format "-:%{line}:%{column}: %{kind}: [%{check}] %{message}"'
|
||||||
|
\ . ' %t',
|
||||||
\ 'callback': 'ale#handlers#HandleGCCFormat',
|
\ 'callback': 'ale#handlers#HandleGCCFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -5,8 +5,6 @@ call ale#linter#Define('pyrex', {
|
|||||||
\ 'name': 'cython',
|
\ 'name': 'cython',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'cython',
|
\ 'executable': 'cython',
|
||||||
\ 'command': g:ale#util#stdin_wrapper
|
\ 'command': 'cython --warning-extra -o ' . g:ale#util#nul_file . ' %t',
|
||||||
\ . ' .pyx cython --warning-extra -o '
|
|
||||||
\ . g:ale#util#nul_file,
|
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsError',
|
||||||
\})
|
\})
|
||||||
|
@ -10,10 +10,9 @@ function! g:ale_linters#python#mypy#GetCommand(buffer) abort
|
|||||||
\ ? 'MYPYPATH=' . l:automatic_stubs_dir . ' '
|
\ ? 'MYPYPATH=' . l:automatic_stubs_dir . ' '
|
||||||
\ : ''
|
\ : ''
|
||||||
|
|
||||||
return l:automatic_stubs_command
|
return 'mypy --show-column-numbers '
|
||||||
\ . g:ale#util#stdin_wrapper
|
|
||||||
\ . ' .py mypy --show-column-numbers '
|
|
||||||
\ . g:ale_python_mypy_options
|
\ . g:ale_python_mypy_options
|
||||||
|
\ . ' %t'
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
let s:path_pattern = '[a-zA-Z]\?\\\?:\?[[:alnum:]/\.\-_]\+'
|
let s:path_pattern = '[a-zA-Z]\?\\\?:\?[[:alnum:]/\.\-_]\+'
|
||||||
|
@ -12,10 +12,10 @@ function! ale_linters#python#pylint#GetExecutable(buffer) abort
|
|||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#python#pylint#GetCommand(buffer) abort
|
function! ale_linters#python#pylint#GetCommand(buffer) abort
|
||||||
return g:ale#util#stdin_wrapper . ' .py '
|
return ale_linters#python#pylint#GetExecutable(a:buffer)
|
||||||
\ . ale_linters#python#pylint#GetExecutable(a:buffer)
|
|
||||||
\ . ' ' . g:ale_python_pylint_options
|
\ . ' ' . g:ale_python_pylint_options
|
||||||
\ . ' --output-format text --msg-template="{path}:{line}:{column}: {msg_id} {msg}" --reports n'
|
\ . ' --output-format text --msg-template="{path}:{line}:{column}: {msg_id} {msg}" --reports n'
|
||||||
|
\ . ' %t'
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
call ale#linter#Define('python', {
|
call ale#linter#Define('python', {
|
||||||
|
@ -3,6 +3,6 @@
|
|||||||
call ale#linter#Define('sass', {
|
call ale#linter#Define('sass', {
|
||||||
\ 'name': 'sasslint',
|
\ 'name': 'sasslint',
|
||||||
\ 'executable': 'sass-lint',
|
\ 'executable': 'sass-lint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .sass sass-lint -v -q -f compact',
|
\ 'command': 'sass-lint -v -q -f compact %t',
|
||||||
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
" vim: set et:
|
|
||||||
" Author: Zoltan Kalmar - https://github.com/kalmiz
|
" Author: Zoltan Kalmar - https://github.com/kalmiz
|
||||||
" Description: Basic scala support using scalac
|
" Description: Basic scala support using scalac
|
||||||
|
|
||||||
@ -21,8 +20,10 @@ function! ale_linters#scala#scalac#Handle(buffer, lines) abort
|
|||||||
let l:text = l:match[3]
|
let l:text = l:match[3]
|
||||||
let l:type = l:match[2] ==# 'error' ? 'E' : 'W'
|
let l:type = l:match[2] ==# 'error' ? 'E' : 'W'
|
||||||
let l:col = 0
|
let l:col = 0
|
||||||
|
|
||||||
if l:ln + 1 < len(a:lines)
|
if l:ln + 1 < len(a:lines)
|
||||||
let l:col = stridx(a:lines[l:ln + 1], '^')
|
let l:col = stridx(a:lines[l:ln + 1], '^')
|
||||||
|
|
||||||
if l:col == -1
|
if l:col == -1
|
||||||
let l:col = 0
|
let l:col = 0
|
||||||
endif
|
endif
|
||||||
@ -47,6 +48,6 @@ call ale#linter#Define('scala', {
|
|||||||
\ 'name': 'scalac',
|
\ 'name': 'scalac',
|
||||||
\ 'executable': 'scalac',
|
\ 'executable': 'scalac',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .scala scalac -Ystop-after:parser',
|
\ 'command': 'scalac -Ystop-after:parser %t',
|
||||||
\ 'callback': 'ale_linters#scala#scalac#Handle',
|
\ 'callback': 'ale_linters#scala#scalac#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -3,6 +3,6 @@
|
|||||||
call ale#linter#Define('scss', {
|
call ale#linter#Define('scss', {
|
||||||
\ 'name': 'sasslint',
|
\ 'name': 'sasslint',
|
||||||
\ 'executable': 'sass-lint',
|
\ 'executable': 'sass-lint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .scss sass-lint -v -q -f compact',
|
\ 'command': 'sass-lint -v -q -f compact %t',
|
||||||
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
\ 'callback': 'ale#handlers#HandleCSSLintFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -4,6 +4,14 @@
|
|||||||
let g:ale_tex_lacheck_executable =
|
let g:ale_tex_lacheck_executable =
|
||||||
\ get(g:, 'ale_tex_lacheck_executable', 'lacheck')
|
\ get(g:, 'ale_tex_lacheck_executable', 'lacheck')
|
||||||
|
|
||||||
|
function! ale_linters#tex#lacheck#GetExecutable(buffer) abort
|
||||||
|
return g:ale_tex_lacheck_executable
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#tex#lacheck#GetCommand(buffer) abort
|
||||||
|
return g:ale_tex_lacheck_executable . ' %t'
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#tex#lacheck#Handle(buffer, lines) abort
|
function! ale_linters#tex#lacheck#Handle(buffer, lines) abort
|
||||||
" Mattes lines like:
|
" Mattes lines like:
|
||||||
"
|
"
|
||||||
@ -43,8 +51,7 @@ endfunction
|
|||||||
|
|
||||||
call ale#linter#Define('tex', {
|
call ale#linter#Define('tex', {
|
||||||
\ 'name': 'lacheck',
|
\ 'name': 'lacheck',
|
||||||
\ 'executable': 'lacheck',
|
\ 'executable_callback': 'ale_linters#tex#lacheck#GetExecutable',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .tex '
|
\ 'command_callback': 'ale_linters#tex#lacheck#GetCommand',
|
||||||
\ . g:ale_tex_lacheck_executable,
|
|
||||||
\ 'callback': 'ale_linters#tex#lacheck#Handle'
|
\ 'callback': 'ale_linters#tex#lacheck#Handle'
|
||||||
\})
|
\})
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
call ale#linter#Define('tex', {
|
call ale#linter#Define('tex', {
|
||||||
\ 'name': 'proselint',
|
\ 'name': 'proselint',
|
||||||
\ 'executable': 'proselint',
|
\ 'executable': 'proselint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .tex proselint',
|
\ 'command': 'proselint %t',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
||||||
\})
|
\})
|
||||||
|
@ -5,5 +5,5 @@ call ale#linter#Define('text', {
|
|||||||
\ 'name': 'proselint',
|
\ 'name': 'proselint',
|
||||||
\ 'executable': 'proselint',
|
\ 'executable': 'proselint',
|
||||||
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
\ 'callback': 'ale#handlers#HandleUnixFormatAsWarning',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .txt proselint',
|
\ 'command': 'proselint %t',
|
||||||
\})
|
\})
|
||||||
|
@ -38,13 +38,11 @@ function! ale_linters#typescript#tslint#Handle(buffer, lines) abort
|
|||||||
return l:output
|
return l:output
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#typescript#tslint#BuildLintCommand(buffer_n) abort
|
function! ale_linters#typescript#tslint#BuildLintCommand(buffer) abort
|
||||||
let l:tsconfig_path = ale#util#FindNearestFile(a:buffer_n, 'tslint.json')
|
let l:tsconfig_path = ale#util#FindNearestFile(a:buffer, 'tslint.json')
|
||||||
let l:tslint_options = empty(l:tsconfig_path) ? '' : '-c ' . l:tsconfig_path
|
let l:tslint_options = empty(l:tsconfig_path) ? '' : '-c ' . l:tsconfig_path
|
||||||
|
|
||||||
let l:ext = '.' . fnamemodify(bufname(a:buffer_n), ':e')
|
return 'tslint ' . l:tslint_options . ' %t'
|
||||||
|
|
||||||
return g:ale#util#stdin_wrapper . ' ' . l:ext . ' tslint ' . l:tslint_options
|
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
call ale#linter#Define('typescript', {
|
call ale#linter#Define('typescript', {
|
||||||
|
@ -40,6 +40,6 @@ call ale#linter#Define('verilog', {
|
|||||||
\ 'name': 'iverilog',
|
\ 'name': 'iverilog',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'iverilog',
|
\ 'executable': 'iverilog',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .v iverilog -t null -Wall',
|
\ 'command': 'iverilog -t null -Wall %t',
|
||||||
\ 'callback': 'ale_linters#verilog#iverilog#Handle',
|
\ 'callback': 'ale_linters#verilog#iverilog#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -1,6 +1,16 @@
|
|||||||
" Author: Masahiro H https://github.com/mshr-h
|
" Author: Masahiro H https://github.com/mshr-h
|
||||||
" Description: verilator for verilog files
|
" Description: verilator for verilog files
|
||||||
|
|
||||||
|
function! ale_linters#verilog#verilator#GetCommand(buffer) abort
|
||||||
|
let l:filename = tempname() . '_verilator_linted.v'
|
||||||
|
|
||||||
|
" Create a special filename, so we can detect it in the handler.
|
||||||
|
call ale#engine#ManageFile(a:buffer, l:filename)
|
||||||
|
call writefile(getbufline(a:buffer, 1, '$'), l:filename)
|
||||||
|
|
||||||
|
return 'verilator --lint-only -Wall -Wno-DECLFILENAME ' . fnameescape(l:filename)
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#verilog#verilator#Handle(buffer, lines) abort
|
function! ale_linters#verilog#verilator#Handle(buffer, lines) abort
|
||||||
" Look for lines like the following.
|
" Look for lines like the following.
|
||||||
"
|
"
|
||||||
@ -25,7 +35,7 @@ function! ale_linters#verilog#verilator#Handle(buffer, lines) abort
|
|||||||
let l:text = l:match[4]
|
let l:text = l:match[4]
|
||||||
let l:file = l:match[2]
|
let l:file = l:match[2]
|
||||||
|
|
||||||
if(l:file =~# '_verilator_linted.v')
|
if l:file =~# '_verilator_linted.v'
|
||||||
call add(l:output, {
|
call add(l:output, {
|
||||||
\ 'bufnr': a:buffer,
|
\ 'bufnr': a:buffer,
|
||||||
\ 'lnum': l:line,
|
\ 'lnum': l:line,
|
||||||
@ -45,6 +55,7 @@ call ale#linter#Define('verilog', {
|
|||||||
\ 'name': 'verilator',
|
\ 'name': 'verilator',
|
||||||
\ 'output_stream': 'stderr',
|
\ 'output_stream': 'stderr',
|
||||||
\ 'executable': 'verilator',
|
\ 'executable': 'verilator',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' _verilator_linted.v verilator --lint-only -Wall -Wno-DECLFILENAME',
|
\ 'command_callback': 'ale_linters#verilog#verilator#GetCommand',
|
||||||
\ 'callback': 'ale_linters#verilog#verilator#Handle',
|
\ 'callback': 'ale_linters#verilog#verilator#Handle',
|
||||||
|
\ 'read_buffer': 0,
|
||||||
\})
|
\})
|
||||||
|
@ -12,11 +12,11 @@ let s:format = '-f "{file_path}:{line_number}:{column_number}: {severity}: {desc
|
|||||||
call ale#linter#Define('vim', {
|
call ale#linter#Define('vim', {
|
||||||
\ 'name': 'vint',
|
\ 'name': 'vint',
|
||||||
\ 'executable': 'vint',
|
\ 'executable': 'vint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper
|
\ 'command': 'vint '
|
||||||
\ . ' .vim vint '
|
|
||||||
\ . s:warning_flag
|
\ . s:warning_flag
|
||||||
\ . ' --no-color '
|
\ . ' --no-color '
|
||||||
\ . s:enable_neovim
|
\ . s:enable_neovim
|
||||||
\ . s:format,
|
\ . s:format
|
||||||
|
\ . ' %t',
|
||||||
\ 'callback': 'ale#handlers#HandleGCCFormat',
|
\ 'callback': 'ale#handlers#HandleGCCFormat',
|
||||||
\})
|
\})
|
||||||
|
@ -37,6 +37,6 @@ endfunction
|
|||||||
call ale#linter#Define('yaml', {
|
call ale#linter#Define('yaml', {
|
||||||
\ 'name': 'yamllint',
|
\ 'name': 'yamllint',
|
||||||
\ 'executable': 'yamllint',
|
\ 'executable': 'yamllint',
|
||||||
\ 'command': g:ale#util#stdin_wrapper . ' .yml yamllint -f parsable',
|
\ 'command': 'yamllint -f parsable %t',
|
||||||
\ 'callback': 'ale_linters#yaml#yamllint#Handle',
|
\ 'callback': 'ale_linters#yaml#yamllint#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -1,23 +1,6 @@
|
|||||||
" Author: w0rp <devw0rp@gmail.com>
|
" Author: w0rp <devw0rp@gmail.com>
|
||||||
" Description: Contains miscellaneous functions
|
" Description: Contains miscellaneous functions
|
||||||
|
|
||||||
function! s:FindWrapperScript() abort
|
|
||||||
for l:parent in split(&runtimepath, ',')
|
|
||||||
" Expand the path to deal with ~ issues.
|
|
||||||
let l:path = expand(l:parent . '/' . 'stdin-wrapper')
|
|
||||||
|
|
||||||
if filereadable(l:path)
|
|
||||||
if has('win32')
|
|
||||||
return l:path . '.exe'
|
|
||||||
endif
|
|
||||||
|
|
||||||
return l:path
|
|
||||||
endif
|
|
||||||
endfor
|
|
||||||
endfunction
|
|
||||||
|
|
||||||
let g:ale#util#stdin_wrapper = s:FindWrapperScript()
|
|
||||||
|
|
||||||
" A null file for sending output to nothing.
|
" A null file for sending output to nothing.
|
||||||
let g:ale#util#nul_file = '/dev/null'
|
let g:ale#util#nul_file = '/dev/null'
|
||||||
|
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Authors: w0rp <devw0rp@gmail.com>, hauleth <lukasz@niemier.pl>
|
|
||||||
# Description: This script implements a wrapper for any program which does not accept
|
|
||||||
# stdin input on most Unix machines. The input to the script is read to a
|
|
||||||
# temporary file, and the first argument sets a particular file extension
|
|
||||||
# for the temporary file.
|
|
||||||
|
|
||||||
set -eu
|
|
||||||
|
|
||||||
# All of the following arguments are read as command to run.
|
|
||||||
file_extension="$1"
|
|
||||||
shift
|
|
||||||
|
|
||||||
temp_dir=$(mktemp -d 2>/dev/null || mktemp -d -t 'ale_linter')
|
|
||||||
temp_file="$temp_dir/file$file_extension"
|
|
||||||
trap 'rm -r "$temp_dir"' EXIT
|
|
||||||
|
|
||||||
cat > "$temp_file"
|
|
||||||
|
|
||||||
"$@" "$temp_file"
|
|
Binary file not shown.
@ -1,84 +0,0 @@
|
|||||||
// Author: w0rp <devw0rp@gmail.com>
|
|
||||||
// Description: This file provides a D program for implementing
|
|
||||||
// the stdin-wrapper on Windows.
|
|
||||||
|
|
||||||
import std.algorithm;
|
|
||||||
import std.array;
|
|
||||||
import std.file;
|
|
||||||
import std.process;
|
|
||||||
import std.stdio;
|
|
||||||
import std.path;
|
|
||||||
|
|
||||||
@safe
|
|
||||||
auto createTemporaryFilename(string fileExtension) {
|
|
||||||
import std.uuid;
|
|
||||||
|
|
||||||
string filename;
|
|
||||||
|
|
||||||
do {
|
|
||||||
const randomPart = randomUUID().toString.replace("-", "_");
|
|
||||||
|
|
||||||
filename = buildPath(tempDir(), "ale_" ~ randomPart ~ fileExtension);
|
|
||||||
} while (exists(filename));
|
|
||||||
|
|
||||||
return filename;
|
|
||||||
}
|
|
||||||
|
|
||||||
@trusted
|
|
||||||
void readStdinToFile(ref File tempFile) {
|
|
||||||
stdin.byChunk(4096).copy(tempFile.lockingTextWriter());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Expand program names like "csslint" to "csslint.cmd"
|
|
||||||
// D is not able to perform this kind of expanstion in spawnProcess
|
|
||||||
@safe
|
|
||||||
string expandedProgramName(string name) {
|
|
||||||
auto extArray = environment["PATHEXT"].split(";");
|
|
||||||
|
|
||||||
foreach(pathDir; environment["PATH"].split(";")) {
|
|
||||||
foreach(extension; extArray) {
|
|
||||||
const candidate = buildPath(pathDir, name ~ extension);
|
|
||||||
|
|
||||||
if (exists(candidate)) {
|
|
||||||
return candidate;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// We were given a full path for a program name, so use that.
|
|
||||||
if (exists(name)) {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
@trusted
|
|
||||||
int runLinterProgram(string[] args) {
|
|
||||||
const expandedName = expandedProgramName(args[0]);
|
|
||||||
|
|
||||||
writeln(expandedName);
|
|
||||||
|
|
||||||
if (expandedName) {
|
|
||||||
return wait(spawnProcess([expandedName] ~ args[1..$]));
|
|
||||||
}
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
@safe
|
|
||||||
int main(string[] args) {
|
|
||||||
const filename = createTemporaryFilename(args[1]);
|
|
||||||
|
|
||||||
auto tempFile = File(filename, "w");
|
|
||||||
|
|
||||||
scope(exit) {
|
|
||||||
tempFile.close();
|
|
||||||
remove(filename);
|
|
||||||
}
|
|
||||||
|
|
||||||
readStdinToFile(tempFile);
|
|
||||||
tempFile.close();
|
|
||||||
|
|
||||||
return runLinterProgram(args[2..$] ~ [filename]);
|
|
||||||
}
|
|
@ -1,4 +0,0 @@
|
|||||||
Execute(We should be able to find the stdin-wrapper script):
|
|
||||||
silent! cd /testplugin/test
|
|
||||||
|
|
||||||
AssertEqual expand('%:p:h:h') . '/stdin-wrapper', ale#util#stdin_wrapper
|
|
Loading…
x
Reference in New Issue
Block a user