diff options
-rw-r--r-- | autoload/ale/handlers/python.vim | 23 | ||||
-rw-r--r-- | test/handler/test_flake8_handler.vader | 47 |
2 files changed, 68 insertions, 2 deletions
diff --git a/autoload/ale/handlers/python.vim b/autoload/ale/handlers/python.vim index 58e7d757..ba1cc57f 100644 --- a/autoload/ale/handlers/python.vim +++ b/autoload/ale/handlers/python.vim @@ -1,6 +1,13 @@ " Author: w0rp <devw0rp@gmail.com> " Description: Error handling for flake8, etc. +let s:end_col_pattern_map = { +\ 'F405': '\(.\+\) may be undefined', +\ 'F821': 'undefined name ''\([^'']\+\)''', +\ 'F999': '^''\([^'']\+\)''', +\ 'F841': 'local variable ''\([^'']\+\)''', +\} + function! ale#handlers#python#HandlePEP8Format(buffer, lines) abort for l:line in a:lines[:10] if match(l:line, '^Traceback') >= 0 @@ -35,12 +42,24 @@ function! ale#handlers#python#HandlePEP8Format(buffer, lines) abort continue endif - call add(l:output, { + let l:item = { \ 'lnum': l:match[1] + 0, \ 'col': l:match[2] + 0, \ 'text': l:code . ': ' . l:match[4], \ 'type': l:code[:0] ==# 'E' ? 'E' : 'W', - \}) + \} + + let l:end_col_pattern = get(s:end_col_pattern_map, l:code, '') + + if !empty(l:end_col_pattern) + let l:end_col_match = matchlist(l:match[4], l:end_col_pattern) + + if !empty(l:end_col_match) + let l:item.end_col = l:item.col + len(l:end_col_match[1]) - 1 + endif + endif + + call add(l:output, l:item) endfor return l:output diff --git a/test/handler/test_flake8_handler.vader b/test/handler/test_flake8_handler.vader new file mode 100644 index 00000000..15345d89 --- /dev/null +++ b/test/handler/test_flake8_handler.vader @@ -0,0 +1,47 @@ + +Execute(End column indexes should be set for certain errors): + AssertEqual + \ [ + \ { + \ 'lnum': 25, + \ 'col': 1, + \ 'type': 'W', + \ 'end_col': 3, + \ 'text': 'F821: undefined name ''foo''', + \ }, + \ { + \ 'lnum': 28, + \ 'col': 5, + \ 'type': 'W', + \ 'end_col': 9, + \ 'text': 'F405: hello may be undefined, or defined from star imports: x', + \ }, + \ { + \ 'lnum': 104, + \ 'col': 5, + \ 'type': 'W', + \ 'end_col': 12, + \ 'text': 'F999: ''continue'' not properly in loop', + \ }, + \ { + \ 'lnum': 106, + \ 'col': 5, + \ 'type': 'W', + \ 'end_col': 9, + \ 'text': 'F999: ''break'' outside loop', + \ }, + \ { + \ 'lnum': 109, + \ 'col': 5, + \ 'type': 'W', + \ 'end_col': 8, + \ 'text': 'F841: local variable ''test'' is assigned to but never used', + \ }, + \ ], + \ ale#handlers#python#HandlePEP8Format(1, [ + \ 'foo.py:25:1: F821 undefined name ''foo''', + \ 'foo.py:28:5: F405 hello may be undefined, or defined from star imports: x', + \ 'foo.py:104:5: F999 ''continue'' not properly in loop', + \ 'foo.py:106:5: F999 ''break'' outside loop', + \ 'foo.py:109:5: F841 local variable ''test'' is assigned to but never used', + \ ]) |