ea7f68226e
GetCommand conditionally adds a filter (implemented as inline Ruby code in the command line) to transform some of the problematic Rails-specific eRuby syntax. Specifically, <%= tags are replaced with <%. This does not reduce the effectiveness of the linter, because the transformed code is still evaluated. This solution was suggested by @rgo at https://github.com/w0rp/ale/issues/580#issuecomment-337676607.
26 lines
976 B
VimL
26 lines
976 B
VimL
" Author: Matthias Guenther - https://wikimatze.de, Eddie Lebow https://github.com/elebow
|
|
" Description: ERB from the Ruby standard library, for eruby/erb files
|
|
|
|
function! ale_linters#eruby#erb#GetCommand(buffer) abort
|
|
let l:rails_root = ale#ruby#FindRailsRoot(a:buffer)
|
|
|
|
if empty(l:rails_root)
|
|
return 'erb -P -x %t | ruby -c'
|
|
endif
|
|
|
|
" Rails-flavored eRuby does not comply with the standard as understood by
|
|
" ERB, so we'll have to do some substitution. This does not reduce the
|
|
" effectiveness of the linter—the translated code is still evaluated.
|
|
return 'ruby -r erb -e ' . ale#Escape('puts ERB.new($stdin.read.gsub(%{<%=},%{<%}), nil, %{-}).src') . ' | ruby -c'
|
|
endfunction
|
|
|
|
call ale#linter#Define('eruby', {
|
|
\ 'name': 'erb',
|
|
\ 'aliases': ['erubylint'],
|
|
\ 'executable': 'erb',
|
|
\ 'output_stream': 'stderr',
|
|
\ 'command_callback': 'ale_linters#eruby#erb#GetCommand',
|
|
\ 'callback': 'ale#handlers#ruby#HandleSyntaxErrors',
|
|
\})
|
|
|