Update error-parser for nix-instantiate on Nix 2.4+

In the (unreleased) Nix 2.4 the error-messages have been reformatted[1].
This patch aims to retain proper `.nix`-support in `ale`, for both
stable Nix (2.3 and older) and unstable Nix (2.4 and newer).

[1] https://github.com/NixOS/nix/pull/3590
This commit is contained in:
Maximilian Bosch 2020-07-06 20:01:52 +02:00
parent 9a1e91e075
commit 72dbd7f648
No known key found for this signature in database
GPG key ID: 091DBF4D1FC46B8E
2 changed files with 70 additions and 10 deletions

View file

@ -1,18 +1,51 @@
" Author: Alistair Bill <@alibabzo> " Author: Alistair Bill <@alibabzo>
" Author: Maximilian Bosch <maximilian@mbosch.me>
" Description: nix-instantiate linter for nix files " Description: nix-instantiate linter for nix files
function! ale_linters#nix#nix#Command(buffer, output, meta) abort
let l:version = a:output[0][22:]
if l:version =~# '^\(2.4\|3\).*'
return 'nix-instantiate --log-format internal-json --parse -'
else
return 'nix-instantiate --parse -'
endif
endfunction
function! ale_linters#nix#nix#Handle(buffer, lines) abort function! ale_linters#nix#nix#Handle(buffer, lines) abort
let l:pattern = '^\(.\+\): \(.\+\), at .*:\(\d\+\):\(\d\+\)$'
let l:output = [] let l:output = []
for l:match in ale#util#GetMatches(a:lines, l:pattern) if empty(a:lines)
call add(l:output, { return l:output
\ 'lnum': l:match[3] + 0, endif
\ 'col': l:match[4] + 0,
\ 'text': l:match[1] . ': ' . l:match[2], if a:lines[0] =~# '^@nix .*'
\ 'type': l:match[1] =~# '^error' ? 'E' : 'W', for l:line in a:lines
\}) if l:line =~# '^@nix .*'
endfor let l:result = json_decode(strpart(l:line, 4))
if has_key(l:result, 'column')
call add(l:output, {
\ 'type': 'E',
\ 'lnum': l:result.line,
\ 'col': l:result.column,
\ 'text': l:result.raw_msg
\})
endif
endif
endfor
else
let l:pattern = '^\(.\+\): \(.\+\) at .*:\(\d\+\):\(\d\+\)$'
for l:match in ale#util#GetMatches(a:lines, l:pattern)
call add(l:output, {
\ 'lnum': l:match[3] + 0,
\ 'col': l:match[4] + 0,
\ 'text': l:match[1] . ': ' . substitute(l:match[2], ',$', '', ''),
\ 'type': l:match[1] =~# '^error' ? 'E' : 'W',
\})
endfor
endif
return l:output return l:output
endfunction endfunction
@ -21,6 +54,10 @@ call ale#linter#Define('nix', {
\ 'name': 'nix', \ 'name': 'nix',
\ 'output_stream': 'stderr', \ 'output_stream': 'stderr',
\ 'executable': 'nix-instantiate', \ 'executable': 'nix-instantiate',
\ 'command': 'nix-instantiate --parse -', \ 'command': {buffer -> ale#command#Run(
\ buffer,
\ 'nix-instantiate --version',
\ function('ale_linters#nix#nix#Command')
\ )},
\ 'callback': 'ale_linters#nix#nix#Handle', \ 'callback': 'ale_linters#nix#nix#Handle',
\}) \})

View file

@ -5,6 +5,29 @@ After:
call ale#linter#Reset() call ale#linter#Reset()
Execute(The nix handler should parse nix-instantiate error messages correctly): Execute(The nix handler should parse nix-instantiate error messages correctly):
AssertEqual
\ [
\ {
\ 'lnum': 6,
\ 'col': 3,
\ 'type': 'E',
\ 'text': "syntax error, unexpected ']', expecting ';'",
\ },
\ {
\ 'lnum': 3,
\ 'col': 5,
\ 'type': 'E',
\ 'text': "undefined variable 'foo'",
\ },
\
\ ],
\ ale_linters#nix#nix#Handle(bufnr(''), [
\ "@nix {\"line\":6,\"column\":3,\"raw_msg\":\"syntax error, unexpected ']', expecting ';'\"}",
\ "@nix {\"line\":3,\"column\":5,\"raw_msg\":\"undefined variable 'foo'\"}",
\ "@nix {\"unrelated\":\"message\"}"
\ ])
Execute(The nix handler should parse message from old nix-instantiate correctly):
AssertEqual AssertEqual
\ [ \ [
\ { \ {