summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdriaan Zonnenberg <amz@adriaan.xyz>2017-02-15 23:59:18 +0100
committerAdriaan Zonnenberg <amz@adriaan.xyz>2017-02-15 23:59:18 +0100
commitb2241e991bee98e5a085384061bd5e2de4026afc (patch)
tree3a1ed5c3404611846c38ed37c7ffe04e6794958a
parent2e7050dbe2cdce030ed2f4189b9a904e67b352af (diff)
downloadale-b2241e991bee98e5a085384061bd5e2de4026afc.zip
Support columns on php handler
Also added some tests for different error messages
-rw-r--r--ale_linters/php/php.vim9
-rw-r--r--test/test_php_handler.vader59
2 files changed, 64 insertions, 4 deletions
diff --git a/ale_linters/php/php.vim b/ale_linters/php/php.vim
index b807fee9..1127b94a 100644
--- a/ale_linters/php/php.vim
+++ b/ale_linters/php/php.vim
@@ -4,8 +4,9 @@
function! ale_linters#php#php#Handle(buffer, lines) abort
" Matches patterns like the following:
"
- " Parse error: parse error in - on line 7
- let l:pattern = 'Parse error:\s\+\(.\+\) on line \(\d\+\)'
+ " PHP Parse error: syntax error, unexpected ';', expecting ']' in - on line 15
+ let l:pattern = ':\s\+\(.\+unexpected ''\(.\{-}\)''.*\) in - on line \(\d\+\)'
+
let l:output = []
for l:line in a:lines
@@ -18,9 +19,9 @@ function! ale_linters#php#php#Handle(buffer, lines) abort
" vcol is needed to indicate that the column is a character.
call add(l:output, {
\ 'bufnr': a:buffer,
- \ 'lnum': l:match[2] + 0,
+ \ 'lnum': l:match[3] + 0,
\ 'vcol': 0,
- \ 'col': 1,
+ \ 'col': match(getline(l:match[3]), l:match[2]) + 1,
\ 'text': l:match[1],
\ 'type': 'E',
\ 'nr': -1,
diff --git a/test/test_php_handler.vader b/test/test_php_handler.vader
new file mode 100644
index 00000000..11bb2d53
--- /dev/null
+++ b/test/test_php_handler.vader
@@ -0,0 +1,59 @@
+Execute(The php handler should parse lines correctly):
+ runtime ale_linters/php/php.vim
+
+ AssertEqual
+ \ [
+ \ {
+ \ 'bufnr': 347,
+ \ 'lnum': 47,
+ \ 'vcol': 0,
+ \ 'col': 0,
+ \ 'text': "syntax error, unexpected ';', expecting ']'",
+ \ 'type': 'E',
+ \ 'nr': -1,
+ \ },
+ \ {
+ \ 'bufnr': 347,
+ \ 'lnum': 56,
+ \ 'vcol': 0,
+ \ 'col': 0,
+ \ 'text': "syntax error, unexpected '/', expecting function (T_FUNCTION) or const (T_CONST)",
+ \ 'type': 'E',
+ \ 'nr': -1,
+ \ },
+ \ {
+ \ 'bufnr': 347,
+ \ 'lnum': 13,
+ \ 'vcol': 0,
+ \ 'col': 0,
+ \ 'text': "syntax error, unexpected ')'",
+ \ 'type': 'E',
+ \ 'nr': -1,
+ \ },
+ \ ],
+ \ ale_linters#php#php#Handle(347, [
+ \ 'This line should be ignored completely',
+ \ "PHP Parse error: syntax error, unexpected ';', expecting ']' in - on line 47",
+ \ "PHP Parse error: syntax error, unexpected '/', expecting function (T_FUNCTION) or const (T_CONST) in - on line 56",
+ \ 'This line should be ignored completely',
+ \ "PHP Parse error: syntax error, unexpected ')' in - on line 13",
+ \ ])
+
+After:
+ call ale#linter#Reset()
+
+
+Given php(A function call with missing argument delimiters):
+ <?php
+ unset($foo $bar)
+
+Execute(The php handler should find columns correctly):
+ call ale#Lint()
+ call ale#engine#WaitForJobs(2000)
+
+ AssertEqual
+ \ [
+ \ {'group': 'ALEError', 'id': 4, 'pos1': [2, 12, 1], 'priority': 10},
+ \ {'group': 'ALEError', 'id': 5, 'pos1': [2, 12, 1], 'priority': 10}
+ \ ],
+ \ getmatches()