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:
parent
9a1e91e075
commit
72dbd7f648
2 changed files with 70 additions and 10 deletions
|
@ -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',
|
||||||
\})
|
\})
|
||||||
|
|
|
@ -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
|
||||||
\ [
|
\ [
|
||||||
\ {
|
\ {
|
||||||
|
|
Reference in a new issue