summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDevon Meunier <devon.meunier@shopify.com>2017-05-17 08:46:47 -0400
committerDevon Meunier <devon.meunier@shopify.com>2017-05-17 08:46:47 -0400
commit3f926de76b74faf534c6e4c79cf3f28e96848b90 (patch)
tree7fcf43211be103c7ece29be0c2cb1d8b647a7e6e
parent9ca51ed035d1fb3cefe28efe0dea60fbe71b4048 (diff)
downloadale-3f926de76b74faf534c6e4c79cf3f28e96848b90.zip
Escape executable
-rw-r--r--ale_linters/ruby/rubocop.vim9
-rw-r--r--test/command_callback/test_rubocop_command_callback.vader20
2 files changed, 12 insertions, 17 deletions
diff --git a/ale_linters/ruby/rubocop.vim b/ale_linters/ruby/rubocop.vim
index d1286f75..786e1af6 100644
--- a/ale_linters/ruby/rubocop.vim
+++ b/ale_linters/ruby/rubocop.vim
@@ -25,14 +25,19 @@ function! ale_linters#ruby#rubocop#Handle(buffer, lines) abort
endfunction
function! ale_linters#ruby#rubocop#GetCommand(buffer) abort
- return ale#Var(a:buffer, 'ruby_rubocop_executable')
+ let l:unescaped = ale#Var(a:buffer, 'ruby_rubocop_executable')
+ let l:executable = ale#Escape(l:unescaped)
+ if l:unescaped =~? 'bundle$'
+ let l:executable = l:executable . ' exec rubocop'
+ endif
+ return l:executable
\ . ' --format emacs --force-exclusion '
\ . ale#Var(a:buffer, 'ruby_rubocop_options')
\ . ' --stdin ' . bufname(a:buffer)
endfunction
function! ale_linters#ruby#rubocop#GetExecutable(buffer) abort
- let l:executable = split(ale#Var(a:buffer, 'ruby_rubocop_executable'))[0]
+ let l:executable = ale#Var(a:buffer, 'ruby_rubocop_executable')
if executable(l:executable)
return l:executable
endif
diff --git a/test/command_callback/test_rubocop_command_callback.vader b/test/command_callback/test_rubocop_command_callback.vader
index 96a63ce6..cda0c230 100644
--- a/test/command_callback/test_rubocop_command_callback.vader
+++ b/test/command_callback/test_rubocop_command_callback.vader
@@ -3,27 +3,17 @@ Before:
Execute(Executable should default to rubocop):
AssertEqual
- \ 'rubocop --format emacs --force-exclusion --stdin ''dummy.py''',
+ \ '''rubocop'' --format emacs --force-exclusion --stdin ''dummy.py''',
\ ale_linters#ruby#rubocop#GetCommand(bufnr(''))
Execute(Should be able to set a custom executable):
let g:ale_ruby_rubocop_executable = 'bin/rubocop'
AssertEqual
- \ 'bin/rubocop --format emacs --force-exclusion --stdin ''dummy.py''',
+ \ '''bin/rubocop'' --format emacs --force-exclusion --stdin ''dummy.py''',
\ ale_linters#ruby#rubocop#GetCommand(bufnr(''))
-Execute(Custom executables should not be escaped):
- let g:ale_ruby_rubocop_executable = 'bundle exec rubocop'
+Execute(Setting bundle appends 'exec rubocop'):
+ let g:ale_ruby_rubocop_executable = 'path to/bundle'
AssertEqual
- \ 'bundle exec rubocop --format emacs --force-exclusion --stdin ''dummy.py''',
+ \ '''path to/bundle'' exec rubocop --format emacs --force-exclusion --stdin ''dummy.py''',
\ ale_linters#ruby#rubocop#GetCommand(bufnr(''))
-
-Execute(Executable callback should return the first token of the executable):
- let g:ale_ruby_rubocop_executable = 'bundle exec rubocop'
- AssertEqual
- \ 'bundle',
- \ ale_linters#ruby#rubocop#GetExecutable(bufnr(''))
- let g:ale_ruby_rubocop_executable = 'bin/rubocop'
- AssertEqual
- \ 'bin/rubocop',
- \ ale_linters#ruby#rubocop#GetExecutable(bufnr(''))