mirror of
https://github.com/dense-analysis/ale
synced 2025-01-20 14:41:02 +00:00
58e8d32d79
This function is generally applicable to Ruby, not just handling linter output.
24 lines
1.0 KiB
VimL
24 lines
1.0 KiB
VimL
" Author: Justin Searls https://github.com/searls, ynonp - https://github.com/ynonp, Eddie Lebow https://github.com/elebow
|
|
" based on the ale rubocop linter
|
|
" Description: StandardRB - Ruby Style Guide, with linter & automatic code fixer
|
|
|
|
call ale#Set('ruby_standardrb_executable', 'standardrb')
|
|
call ale#Set('ruby_standardrb_options', '')
|
|
|
|
function! ale_linters#ruby#standardrb#GetCommand(buffer) abort
|
|
let l:executable = ale#Var(a:buffer, 'ruby_standardrb_executable')
|
|
|
|
return ale#ruby#EscapeExecutable(l:executable, 'standardrb')
|
|
\ . ' --format json --force-exclusion '
|
|
\ . ale#Var(a:buffer, 'ruby_standardrb_options')
|
|
\ . ' --stdin ' . ale#Escape(expand('#' . a:buffer . ':p'))
|
|
endfunction
|
|
|
|
" standardrb is based on RuboCop so the callback is the same
|
|
call ale#linter#Define('ruby', {
|
|
\ 'name': 'standardrb',
|
|
\ 'executable': {b -> ale#Var(b, 'ruby_standardrb_executable')},
|
|
\ 'command': function('ale_linters#ruby#standardrb#GetCommand'),
|
|
\ 'callback': 'ale#ruby#HandleRubocopOutput',
|
|
\})
|