mirror of
https://github.com/dense-analysis/ale.git
synced 2025-12-09 22:14:44 +08:00
#540 Fix shell escaping pretty much everywhere
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
Before:
|
||||
silent! cd /testplugin/test
|
||||
:e! top/middle/bottom/dummy.txt
|
||||
silent file top/middle/bottom/dummy.txt
|
||||
|
||||
After:
|
||||
unlet! g:result
|
||||
@@ -13,29 +13,29 @@ Execute(FormatCommand should handle %%, and ignore other percents):
|
||||
AssertEqual ['', '% %%d %%f %x %'], ale#engine#FormatCommand(bufnr('%'), '%% %%%d %%%f %x %')
|
||||
|
||||
Execute(FormatCommand should convert %s to the current filename):
|
||||
AssertEqual ['', 'foo ' . fnameescape(expand('%:p')) . ' bar ' . fnameescape(expand('%:p'))], ale#engine#FormatCommand(bufnr('%'), 'foo %s bar %s')
|
||||
AssertEqual ['', 'foo ' . shellescape(expand('%:p')) . ' bar ' . shellescape(expand('%:p'))], ale#engine#FormatCommand(bufnr('%'), 'foo %s bar %s')
|
||||
|
||||
Execute(FormatCommand should convert %t to a new temporary filename):
|
||||
let g:result = ale#engine#FormatCommand(bufnr('%'), 'foo %t bar %t')
|
||||
let g:match = matchlist(g:result[1], '\v^foo (/tmp/.*/dummy.txt) bar (/tmp/.*/dummy.txt)$')
|
||||
let g:match = matchlist(g:result[1], '\v^foo (''/tmp/[^'']*/dummy.txt'') bar (''/tmp/[^'']*/dummy.txt'')$')
|
||||
|
||||
Assert !empty(g:match), 'No match found! Result was: ' . g:result[1]
|
||||
" The first item of the result should be a temporary filename, and it should
|
||||
" be the same as the escaped name in the command string.
|
||||
AssertEqual g:result[0], fnameescape(g:match[1])
|
||||
AssertEqual shellescape(g:result[0]), g:match[1]
|
||||
" The two temporary filenames formatted in should be the same.
|
||||
AssertEqual g:match[1], g:match[2]
|
||||
|
||||
Execute(FormatCommand should let you combine %s and %t):
|
||||
let g:result = ale#engine#FormatCommand(bufnr('%'), 'foo %t bar %s')
|
||||
let g:match = matchlist(g:result[1], '\v^foo (/tmp/.*/dummy.txt) bar (.*/dummy.txt)$')
|
||||
let g:match = matchlist(g:result[1], '\v^foo (''/tmp/.*/dummy.txt'') bar (''.*/dummy.txt'')$')
|
||||
|
||||
Assert !empty(g:match), 'No match found! Result was: ' . g:result[1]
|
||||
" The first item of the result should be a temporary filename, and it should
|
||||
" be the same as the escaped name in the command string.
|
||||
AssertEqual g:result[0], fnameescape(g:match[1])
|
||||
AssertEqual shellescape(g:result[0]), g:match[1]
|
||||
" The second item should be equal to the original filename.
|
||||
AssertEqual fnameescape(expand('%:p')), g:match[2]
|
||||
AssertEqual shellescape(expand('%:p')), g:match[2]
|
||||
|
||||
Execute(EscapeCommandPart should escape all percent signs):
|
||||
AssertEqual '%%s %%t %%%% %%s %%t %%%%', ale#engine#EscapeCommandPart('%s %t %% %s %t %%')
|
||||
|
||||
Reference in New Issue
Block a user