a8915d885b
* Add better support for Haskell stack compiler tools This commit adds support for `stack` as the executable of a tool. This follows a pattern that has been implemented for `bundler`'s tool chain. * Move hlint command to linter file * Add vader test for stack exec handling * Update ghc-mod to support stack execution `ghc-mod` was previously broken into 2 linters. 1. ghc_mod 2. stack_ghc_mod This additional linter is not necessary with proper support for executable variables and `stack exec` handling. * Support stack exec in hfmt * Support stack in hdevtools
44 lines
1.4 KiB
VimL
44 lines
1.4 KiB
VimL
" Author: jparoz <jesse.paroz@gmail.com>
|
|
" Description: hlint for Haskell files
|
|
|
|
function! ale_linters#haskell#hlint#Handle(buffer, lines) abort
|
|
let l:output = []
|
|
|
|
for l:error in ale#util#FuzzyJSONDecode(a:lines, [])
|
|
if l:error.severity is# 'Error'
|
|
let l:type = 'E'
|
|
elseif l:error.severity is# 'Suggestion'
|
|
let l:type = 'I'
|
|
else
|
|
let l:type = 'W'
|
|
endif
|
|
|
|
call add(l:output, {
|
|
\ 'lnum': str2nr(l:error.startLine),
|
|
\ 'col': str2nr(l:error.startColumn),
|
|
\ 'end_lnum': str2nr(l:error.endLine),
|
|
\ 'end_col': str2nr(l:error.endColumn),
|
|
\ 'text': l:error.severity . ': ' . l:error.hint . '. Found: ' . l:error.from . ' Why not: ' . l:error.to,
|
|
\ 'type': l:type,
|
|
\})
|
|
endfor
|
|
|
|
return l:output
|
|
endfunction
|
|
|
|
function! ale_linters#haskell#hlint#GetCommand(buffer) abort
|
|
let l:hlintopts = '--color=never --json'
|
|
|
|
return ale#handlers#hlint#GetExecutable(a:buffer)
|
|
\ . ' ' . ale#Var(a:buffer, 'haskell_hlint_options')
|
|
\ . ' ' . l:hlintopts
|
|
\ . ' -'
|
|
endfunction
|
|
|
|
call ale#linter#Define('haskell', {
|
|
\ 'name': 'hlint',
|
|
\ 'executable_callback': ale#VarFunc('haskell_hlint_executable'),
|
|
\ 'command_callback': 'ale_linters#haskell#hlint#GetCommand' ,
|
|
\ 'callback': 'ale_linters#haskell#hlint#Handle',
|
|
\})
|