Fix #516 - Add support for pyflakes for Python
This commit is contained in:
parent
0e96d4576a
commit
49ccfb1a00
5 changed files with 111 additions and 0 deletions
38
ale_linters/python/pyflakes.vim
Normal file
38
ale_linters/python/pyflakes.vim
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
" Author: w0rp <devw0rp@gmail.com>
|
||||||
|
" Description: pyflakes for python files
|
||||||
|
|
||||||
|
call ale#Set('python_pyflakes_executable', 'pyflakes')
|
||||||
|
call ale#Set('python_pyflakes_use_global', 0)
|
||||||
|
|
||||||
|
function! ale_linters#python#pyflakes#GetExecutable(buffer) abort
|
||||||
|
return ale#python#FindExecutable(a:buffer, 'python_pyflakes', ['pyflakes'])
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#python#pyflakes#GetCommand(buffer) abort
|
||||||
|
let l:executable = ale_linters#python#pyflakes#GetExecutable(a:buffer)
|
||||||
|
|
||||||
|
return ale#Escape(l:executable) . ' %t'
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#python#pyflakes#Handle(buffer, lines) abort
|
||||||
|
let l:pattern = '\v^[a-zA-Z]?:?[^:]+:(\d+):(\d+)?:? (.+)$'
|
||||||
|
let l:output = []
|
||||||
|
|
||||||
|
for l:match in ale#util#GetMatches(a:lines, l:pattern)
|
||||||
|
call add(l:output, {
|
||||||
|
\ 'lnum': l:match[1] + 0,
|
||||||
|
\ 'col': l:match[2] + 0,
|
||||||
|
\ 'text': l:match[3],
|
||||||
|
\})
|
||||||
|
endfor
|
||||||
|
|
||||||
|
return l:output
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
call ale#linter#Define('python', {
|
||||||
|
\ 'name': 'pyflakes',
|
||||||
|
\ 'executable_callback': 'ale_linters#python#pyflakes#GetExecutable',
|
||||||
|
\ 'command_callback': 'ale_linters#python#pyflakes#GetCommand',
|
||||||
|
\ 'callback': 'ale_linters#python#pyflakes#Handle',
|
||||||
|
\ 'output_stream': 'both',
|
||||||
|
\})
|
0
test/command_callback/python_paths/with_virtualenv/env/Scripts/pyflakes.exe
vendored
Executable file
0
test/command_callback/python_paths/with_virtualenv/env/Scripts/pyflakes.exe
vendored
Executable file
0
test/command_callback/python_paths/with_virtualenv/env/bin/pyflakes
vendored
Executable file
0
test/command_callback/python_paths/with_virtualenv/env/bin/pyflakes
vendored
Executable file
49
test/command_callback/test_pyflakes_command_callback.vader
Normal file
49
test/command_callback/test_pyflakes_command_callback.vader
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
Before:
|
||||||
|
Save g:ale_python_pyflakes_executable
|
||||||
|
Save g:ale_python_pyflakes_use_global
|
||||||
|
|
||||||
|
unlet! g:ale_python_pyflakes_executable
|
||||||
|
unlet! g:ale_python_pyflakes_use_global
|
||||||
|
|
||||||
|
let b:bin_dir = has('win32') ? 'Scripts' : 'bin'
|
||||||
|
|
||||||
|
call ale#test#SetDirectory('/testplugin/test/command_callback')
|
||||||
|
|
||||||
|
runtime ale_linters/python/pyflakes.vim
|
||||||
|
|
||||||
|
After:
|
||||||
|
Restore
|
||||||
|
|
||||||
|
unlet! b:bin_dir
|
||||||
|
unlet! b:executable
|
||||||
|
|
||||||
|
call ale#test#RestoreDirectory()
|
||||||
|
call ale#linter#Reset()
|
||||||
|
|
||||||
|
Execute(The pyflakes command callback should return default string):
|
||||||
|
AssertEqual ale#Escape('pyflakes') . ' %t',
|
||||||
|
\ ale_linters#python#pyflakes#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
Execute(The pyflakes executable should be configurable):
|
||||||
|
let g:ale_python_pyflakes_executable = '~/.local/bin/pyflakes'
|
||||||
|
|
||||||
|
AssertEqual ale#Escape('~/.local/bin/pyflakes') . ' %t',
|
||||||
|
\ ale_linters#python#pyflakes#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
Execute(The pyflakes executable should be run from the virtualenv path):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
let b:executable = ale#path#Winify(
|
||||||
|
\ g:dir . '/python_paths/with_virtualenv/env/' . b:bin_dir . '/pyflakes'
|
||||||
|
\)
|
||||||
|
|
||||||
|
AssertEqual ale#Escape(b:executable) . ' %t',
|
||||||
|
\ ale_linters#python#pyflakes#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
Execute(You should be able to override the pyflakes virtualenv lookup):
|
||||||
|
call ale#test#SetFilename('python_paths/with_virtualenv/subdir/foo/bar.py')
|
||||||
|
|
||||||
|
let g:ale_python_pyflakes_use_global = 1
|
||||||
|
|
||||||
|
AssertEqual ale#Escape('pyflakes') . ' %t',
|
||||||
|
\ ale_linters#python#pyflakes#GetCommand(bufnr(''))
|
24
test/handler/test_pyflakes_handler.vader
Normal file
24
test/handler/test_pyflakes_handler.vader
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
Before:
|
||||||
|
runtime ale_linters/python/pyflakes.vim
|
||||||
|
|
||||||
|
After:
|
||||||
|
call ale#linter#Reset()
|
||||||
|
|
||||||
|
Execute(The pyflakes handler should handle basic errors):
|
||||||
|
AssertEqual
|
||||||
|
\ [
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 1,
|
||||||
|
\ 'col': 0,
|
||||||
|
\ 'text': 'undefined name ''foo''',
|
||||||
|
\ },
|
||||||
|
\ {
|
||||||
|
\ 'lnum': 1,
|
||||||
|
\ 'col': 7,
|
||||||
|
\ 'text': 'invalid syntax',
|
||||||
|
\ },
|
||||||
|
\ ],
|
||||||
|
\ ale_linters#python#pyflakes#Handle(bufnr(''), [
|
||||||
|
\ 'test.py:1: undefined name ''foo''',
|
||||||
|
\ 'test.py:1:7: invalid syntax',
|
||||||
|
\ ])
|
Reference in a new issue