Send modified lines to jobs, not the file contents

This commit is contained in:
w0rp 2017-05-18 17:50:20 +01:00
parent 05bab00c3c
commit 0b743389e5
2 changed files with 15 additions and 3 deletions

View File

@ -94,7 +94,7 @@ function! ale#fix#RemoveManagedFiles(buffer) abort
let s:buffer_data[a:buffer].temporary_directory_list = [] let s:buffer_data[a:buffer].temporary_directory_list = []
endfunction endfunction
function! s:CreateTemporaryFileForJob(buffer, temporary_file) abort function! s:CreateTemporaryFileForJob(buffer, temporary_file, input) abort
if empty(a:temporary_file) if empty(a:temporary_file)
" There is no file, so we didn't create anything. " There is no file, so we didn't create anything.
return 0 return 0
@ -107,7 +107,7 @@ function! s:CreateTemporaryFileForJob(buffer, temporary_file) abort
" Automatically delete the directory later. " Automatically delete the directory later.
call ale#fix#ManageDirectory(a:buffer, l:temporary_directory) call ale#fix#ManageDirectory(a:buffer, l:temporary_directory)
" Write the buffer out to a file. " Write the buffer out to a file.
call writefile(getbufline(a:buffer, 1, '$'), a:temporary_file) call writefile(a:input, a:temporary_file)
return 1 return 1
endfunction endfunction
@ -115,11 +115,12 @@ endfunction
function! s:RunJob(options) abort function! s:RunJob(options) abort
let l:buffer = a:options.buffer let l:buffer = a:options.buffer
let l:command = a:options.command let l:command = a:options.command
let l:input = a:options.input
let l:output_stream = a:options.output_stream let l:output_stream = a:options.output_stream
let l:read_temporary_file = a:options.read_temporary_file let l:read_temporary_file = a:options.read_temporary_file
let [l:temporary_file, l:command] = ale#command#FormatCommand(l:buffer, l:command, 1) let [l:temporary_file, l:command] = ale#command#FormatCommand(l:buffer, l:command, 1)
call s:CreateTemporaryFileForJob(l:buffer, l:temporary_file) call s:CreateTemporaryFileForJob(l:buffer, l:temporary_file, l:input)
let l:command = ale#job#PrepareCommand(l:command) let l:command = ale#job#PrepareCommand(l:command)
let l:job_options = { let l:job_options = {
@ -202,6 +203,7 @@ function! s:RunFixer(options) abort
let l:job_ran = s:RunJob({ let l:job_ran = s:RunJob({
\ 'buffer': l:buffer, \ 'buffer': l:buffer,
\ 'command': l:result.command, \ 'command': l:result.command,
\ 'input': l:input,
\ 'output_stream': get(l:result, 'output_stream', 'stdout'), \ 'output_stream': get(l:result, 'output_stream', 'stdout'),
\ 'read_temporary_file': get(l:result, 'read_temporary_file', 0), \ 'read_temporary_file': get(l:result, 'read_temporary_file', 0),
\ 'callback_list': a:options.callback_list, \ 'callback_list': a:options.callback_list,

View File

@ -98,6 +98,16 @@ Execute(ALEFix should allow jobs and simple functions to be combined):
Expect(The lines from the temporary file should be modified): Expect(The lines from the temporary file should be modified):
$x $x
Execute(ALEFix should send lines modified by functions to jobs):
let g:ale_fixers.testft = ['AddDollars', 'CatLine']
ALEFix
Expect(The lines should first be modified by the function, then the job):
$a
$b
$c
d
Execute(ALEFix should skip commands when jobs fail to run): Execute(ALEFix should skip commands when jobs fail to run):
let g:ale_emulate_job_failure = 1 let g:ale_emulate_job_failure = 1
let g:ale_fixers.testft = ['CatLine', 'AddDollars'] let g:ale_fixers.testft = ['CatLine', 'AddDollars']