From abe1440268799fd9fba38c71b8423f988523678e Mon Sep 17 00:00:00 2001 From: "D. Ben Knoble" Date: Thu, 1 Oct 2020 12:49:53 -0400 Subject: prolog/swipl: update error format for new version A recent(?) update to swipl changed the error format from Warning: some.pl:2: Singleton variables: [Y] to Warning: some.pl:2: Warning: Singleton variables: [Y] The old error handler doesn't report the correct line numbers and messages on the old format. I've chosen to add a function that covers the second case and detect it, rather than rewrite the current function. This way, both versions should be able to live together. --- Example file that demonstrates the issue (some.pl above): ``` % vim: ft=prolog ii(X, Y) :- X. ``` --- --- ale_linters/prolog/swipl.vim | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) (limited to 'ale_linters/prolog/swipl.vim') diff --git a/ale_linters/prolog/swipl.vim b/ale_linters/prolog/swipl.vim index 5c601c40..70d967f7 100644 --- a/ale_linters/prolog/swipl.vim +++ b/ale_linters/prolog/swipl.vim @@ -34,13 +34,13 @@ function! s:Subst(format, vars) abort return substitute(a:format, '%\(.\)', '\=get(l:vars, submatch(1), "")', 'g') endfunction +let s:pattern = '\v^(ERROR|Warning)+%(:\s*[^:]+:(\d+)%(:(\d+))?)?:\s*(.*)$' function! ale_linters#prolog#swipl#Handle(buffer, lines) abort - let l:pattern = '\v^(ERROR|Warning)+%(:\s*[^:]+:(\d+)%(:(\d+))?)?:\s*(.*)$' let l:output = [] let l:i = 0 while l:i < len(a:lines) - let l:match = matchlist(a:lines[l:i], l:pattern) + let l:match = matchlist(a:lines[l:i], s:pattern) if empty(l:match) let l:i += 1 @@ -65,6 +65,11 @@ endfunction " This returns [, ] function! s:GetErrMsg(i, lines, text) abort + let next_line = get(a:lines, a:i+1, '') + let matches = matchlist(next_line, s:pattern) + if !empty(matchlist) && empty(matches[2]) + return s:GetContErrMsg(a:i+1, a:lines, a:text.matches[4]) + endif if a:text !~# '^\s*$' return [a:i + 1, a:text] endif @@ -80,6 +85,26 @@ function! s:GetErrMsg(i, lines, text) abort return [l:i, join(l:text, '. ')] endfunction +function! s:GetErrMsg(i, lines, text) abort + if a:text !~# '^\s*$' + return [a:i + 1, a:text] + endif + + let l:i = a:i + 1 + let l:text = [] + + while l:i < len(a:lines) && a:lines[l:i] =~# s:pattern + let matches = matchlist(a:lines[l:i], s:pattern) + if !empty(matches[2]) + break + end + call add(l:text, s:Trim(matches[4])) + let l:i += 1 + endwhile + + return [l:i, join(l:text, '. ')] +endfunction + function! s:Trim(str) abort return substitute(a:str, '\v^\s+|\s+$', '', 'g') endfunction -- cgit v1.2.3