Add profile, other options to the perlcritic linter (#675)
* Add profile, other options to the perlcritic linter
This commit is contained in:
parent
411c6b5e9f
commit
3f1cab3e7e
@ -1,17 +1,54 @@
|
|||||||
" Author: Vincent Lequertier <https://github.com/SkySymbol>
|
" Author: Vincent Lequertier <https://github.com/SkySymbol>, Chris Weyl <cweyl@alumni.drew.edu>
|
||||||
" Description: This file adds support for checking perl with perl critic
|
" Description: This file adds support for checking perl with perl critic
|
||||||
|
|
||||||
if !exists('g:ale_perl_perlcritic_showrules')
|
let g:ale_perl_perlcritic_executable =
|
||||||
let g:ale_perl_perlcritic_showrules = 0
|
\ get(g:, 'ale_perl_perlcritic_executable', 'perlcritic')
|
||||||
endif
|
|
||||||
|
let g:ale_perl_perlcritic_profile =
|
||||||
|
\ get(g:, 'ale_perl_perlcritic_profile', '.perlcriticrc')
|
||||||
|
|
||||||
|
let g:ale_perl_perlcritic_options =
|
||||||
|
\ get(g:, 'ale_perl_perlcritic_options', '')
|
||||||
|
|
||||||
|
let g:ale_perl_perlcritic_showrules =
|
||||||
|
\ get(g:, 'ale_perl_perlcritic_showrules', 0)
|
||||||
|
|
||||||
|
function! ale_linters#perl#perlcritic#GetExecutable(buffer) abort
|
||||||
|
return ale#Var(a:buffer, 'perl_perlcritic_executable')
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! ale_linters#perl#perlcritic#GetProfile(buffer) abort
|
||||||
|
|
||||||
|
" first see if we've been overridden
|
||||||
|
let l:profile = ale#Var(a:buffer, 'perl_perlcritic_profile')
|
||||||
|
if l:profile ==? ''
|
||||||
|
return ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
" otherwise, iterate upwards to find it
|
||||||
|
return ale#path#FindNearestFile(a:buffer, l:profile)
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! ale_linters#perl#perlcritic#GetCommand(buffer) abort
|
function! ale_linters#perl#perlcritic#GetCommand(buffer) abort
|
||||||
let l:critic_verbosity = '%l:%c %m\n'
|
let l:critic_verbosity = '%l:%c %m\n'
|
||||||
if g:ale_perl_perlcritic_showrules
|
if ale#Var(a:buffer, 'perl_perlcritic_showrules')
|
||||||
let l:critic_verbosity = '%l:%c %m [%p]\n'
|
let l:critic_verbosity = '%l:%c %m [%p]\n'
|
||||||
endif
|
endif
|
||||||
|
|
||||||
return "perlcritic --verbose '". l:critic_verbosity . "' --nocolor"
|
let l:profile = ale_linters#perl#perlcritic#GetProfile(a:buffer)
|
||||||
|
let l:options = ale#Var(a:buffer, 'perl_perlcritic_options')
|
||||||
|
|
||||||
|
let l:command = ale#Escape(ale_linters#perl#perlcritic#GetExecutable(a:buffer))
|
||||||
|
\ . " --verbose '". l:critic_verbosity . "' --nocolor"
|
||||||
|
|
||||||
|
if l:profile !=? ''
|
||||||
|
let l:command .= ' --profile ' . ale#Escape(l:profile)
|
||||||
|
endif
|
||||||
|
if l:options !=? ''
|
||||||
|
let l:command .= ' ' . l:options
|
||||||
|
endif
|
||||||
|
|
||||||
|
return l:command
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
|
||||||
@ -32,8 +69,8 @@ endfunction
|
|||||||
|
|
||||||
call ale#linter#Define('perl', {
|
call ale#linter#Define('perl', {
|
||||||
\ 'name': 'perlcritic',
|
\ 'name': 'perlcritic',
|
||||||
\ 'executable': 'perlcritic',
|
|
||||||
\ 'output_stream': 'stdout',
|
\ 'output_stream': 'stdout',
|
||||||
|
\ 'executable_callback': 'ale_linters#perl#perlcritic#GetExecutable',
|
||||||
\ 'command_callback': 'ale_linters#perl#perlcritic#GetCommand',
|
\ 'command_callback': 'ale_linters#perl#perlcritic#GetCommand',
|
||||||
\ 'callback': 'ale_linters#perl#perlcritic#Handle',
|
\ 'callback': 'ale_linters#perl#perlcritic#Handle',
|
||||||
\})
|
\})
|
||||||
|
@ -25,6 +25,37 @@ g:ale_perl_perl_options *g:ale_perl_perl_options*
|
|||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
perlcritic *ale-perl-perlcritic*
|
perlcritic *ale-perl-perlcritic*
|
||||||
|
|
||||||
|
g:ale_perl_perlcritic_executable *g:ale_perl_perlcritic_executable*
|
||||||
|
*b:ale_perl_perlcritic_executable*
|
||||||
|
Type: |String|
|
||||||
|
Default: `'perlcritic'`
|
||||||
|
|
||||||
|
This variable can be changed to modify the perlcritic executable used for
|
||||||
|
linting perl.
|
||||||
|
|
||||||
|
|
||||||
|
g:ale_perl_perlcritic_profile *g:ale_perl_perlcritic_profile*
|
||||||
|
*b:ale_perl_perlcritic_profile*
|
||||||
|
Type: |String|
|
||||||
|
Default: `'.perlcriticrc'`
|
||||||
|
|
||||||
|
This variable can be changed to modify the perlcritic profile used for
|
||||||
|
linting perl. The current directory is checked for the file, then the
|
||||||
|
parent directory, etc, until it finds one. If no matching file is found, no
|
||||||
|
profile is passed to perlcritic.
|
||||||
|
|
||||||
|
Set to an empty string to disable using a profile.
|
||||||
|
|
||||||
|
|
||||||
|
g:ale_perl_perlcritic_options *g:ale_perl_perlcritic_options*
|
||||||
|
*b:ale_perl_perlcritic_options*
|
||||||
|
Type: |String|
|
||||||
|
Default: `''`
|
||||||
|
|
||||||
|
This variable can be changed to supply additional command-line arguments to
|
||||||
|
the perlcritic invocation.
|
||||||
|
|
||||||
|
|
||||||
g:ale_perl_perlcritic_showrules *g:ale_perl_perlcritic_showrules*
|
g:ale_perl_perlcritic_showrules *g:ale_perl_perlcritic_showrules*
|
||||||
|
|
||||||
Type: |Number|
|
Type: |Number|
|
||||||
|
62
test/test_perlcritic_linter.vader
Normal file
62
test/test_perlcritic_linter.vader
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
" NOTE: We use the 'b:' forms below to ensure that we're properly using
|
||||||
|
" ale#Var()
|
||||||
|
|
||||||
|
Given perl:
|
||||||
|
#!/usr/bin/env perl
|
||||||
|
use v5.10;
|
||||||
|
say 'Hi there!';
|
||||||
|
|
||||||
|
|
||||||
|
Before:
|
||||||
|
Save g:ale_perl_perlcritic_profile
|
||||||
|
Save g:ale_perl_perlcritic_options
|
||||||
|
Save g:ale_perl_perlcritic_executable
|
||||||
|
Save g:ale_perl_perlcritic_showrules
|
||||||
|
silent! unlet g:ale_perl_perlcritic_options
|
||||||
|
silent! unlet g:ale_perl_perlcritic_executable
|
||||||
|
silent! unlet g:ale_perl_perlcritic_showrules
|
||||||
|
let g:ale_perl_perlcritic_profile = ''
|
||||||
|
|
||||||
|
" enable loading inside test container
|
||||||
|
silent! cd /testplugin
|
||||||
|
source ale_linters/perl/perlcritic.vim
|
||||||
|
|
||||||
|
|
||||||
|
After:
|
||||||
|
Restore
|
||||||
|
silent! unlet b:ale_perl_perlcritic_profile
|
||||||
|
silent! unlet b:ale_perl_perlcritic_options
|
||||||
|
silent! unlet b:ale_perl_perlcritic_executable
|
||||||
|
silent! unlet b:ale_perl_perlcritic_showrules
|
||||||
|
|
||||||
|
|
||||||
|
Execute(no g:ale_perl_perlcritic_showrules):
|
||||||
|
let b:ale_perl_perlcritic_showrules = 0
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ "'perlcritic' --verbose '". '%l:%c %m\n' . "' --nocolor",
|
||||||
|
\ ale_linters#perl#perlcritic#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
|
||||||
|
Execute(yes g:ale_perl_perlcritic_showrules):
|
||||||
|
let b:ale_perl_perlcritic_showrules = 1
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ "'perlcritic' --verbose '". '%l:%c %m [%p]\n' . "' --nocolor",
|
||||||
|
\ ale_linters#perl#perlcritic#GetCommand(bufnr(''))
|
||||||
|
|
||||||
|
|
||||||
|
Execute(set g:ale_perl_perlcritic_profile):
|
||||||
|
let b:ale_perl_perlcritic_profile = 'README.md'
|
||||||
|
|
||||||
|
Assert
|
||||||
|
\ ale_linters#perl#perlcritic#GetCommand(bufnr(''))
|
||||||
|
\ =~# "--profile '.*/README.md'"
|
||||||
|
|
||||||
|
|
||||||
|
Execute(g:ale_perl_perlcritic_options):
|
||||||
|
let b:ale_perl_perlcritic_options = 'beep boop'
|
||||||
|
|
||||||
|
AssertEqual
|
||||||
|
\ "'perlcritic' --verbose '". '%l:%c %m\n' . "' --nocolor beep boop",
|
||||||
|
\ ale_linters#perl#perlcritic#GetCommand(bufnr(''))
|
@ -1,16 +0,0 @@
|
|||||||
Execute(no g:ale_perl_perlcritic_showrules):
|
|
||||||
silent noautocmd new testfile.pl
|
|
||||||
|
|
||||||
let g:ale_perl_perlcritic_showrules = 0
|
|
||||||
|
|
||||||
AssertEqual
|
|
||||||
\ "perlcritic --verbose '". '%l:%c %m\n' . "' --nocolor",
|
|
||||||
\ ale_linters#perl#perlcritic#GetCommand(bufnr(''))
|
|
||||||
|
|
||||||
let g:ale_perl_perlcritic_showrules = 1
|
|
||||||
|
|
||||||
AssertEqual
|
|
||||||
\ "perlcritic --verbose '". '%l:%c %m [%p]\n' . "' --nocolor",
|
|
||||||
\ ale_linters#perl#perlcritic#GetCommand(bufnr(''))
|
|
||||||
|
|
||||||
:q
|
|
Loading…
Reference in New Issue
Block a user