ad7ea36307
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.
21 lines
775 B
Text
21 lines
775 B
Text
Before:
|
|
runtime ale_linters/eruby/erubis.vim
|
|
call ale#test#SetDirectory('/testplugin/test/command_callback')
|
|
|
|
After:
|
|
call ale#linter#Reset()
|
|
call ale#test#RestoreDirectory()
|
|
|
|
Execute(Executable should not contain any filter code by default):
|
|
call ale#test#SetFilename('../ruby_fixtures/not_a_rails_app/file.rb')
|
|
|
|
AssertEqual
|
|
\ 'erubis -x %t | ruby -c',
|
|
\ ale_linters#eruby#erubis#GetCommand(bufnr(''))
|
|
|
|
Execute(Executable should filter invalid eRuby when inside a Rails project):
|
|
call ale#test#SetFilename('../ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb')
|
|
|
|
AssertEqual
|
|
\ 'ruby -r erubis -e ' . ale#Escape('puts Erubis::Eruby.new($stdin.read.gsub(%{<%=},%{<%})).src') . ' | ruby -c',
|
|
\ ale_linters#eruby#erubis#GetCommand(bufnr(''))
|