From 1bf894f48c2169e18e5978c9347e40f186e425ab Mon Sep 17 00:00:00 2001 From: w0rp Date: Tue, 7 Nov 2017 23:20:14 +0000 Subject: Fix #1086 - Implement command chaining for fixers --- autoload/ale/fix.vim | 59 +++++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 51 insertions(+), 8 deletions(-) (limited to 'autoload') diff --git a/autoload/ale/fix.vim b/autoload/ale/fix.vim index 677fb3da..a57ad195 100644 --- a/autoload/ale/fix.vim +++ b/autoload/ale/fix.vim @@ -108,17 +108,27 @@ function! s:HandleExit(job_id, exit_code) abort let l:job_info.output = readfile(l:job_info.file_to_read) endif + let l:chain_callback = get(l:job_info, 'chain_with', v:null) + " Use the output of the job for changing the file if it isn't empty, " otherwise skip this job and use the input from before. - let l:input = !empty(l:job_info.output) + " + " We'll use the input from before for chained commands. + let l:input = l:chain_callback is v:null && !empty(l:job_info.output) \ ? l:job_info.output \ : l:job_info.input + let l:next_index = l:chain_callback is v:null + \ ? l:job_info.callback_index + 1 + \ : l:job_info.callback_index + call s:RunFixer({ \ 'buffer': l:buffer, \ 'input': l:input, + \ 'output': l:job_info.output, \ 'callback_list': l:job_info.callback_list, - \ 'callback_index': l:job_info.callback_index + 1, + \ 'callback_index': l:next_index, + \ 'chain_callback': l:chain_callback, \}) endfunction @@ -172,6 +182,26 @@ function! s:RunJob(options) abort let l:input = a:options.input let l:output_stream = a:options.output_stream let l:read_temporary_file = a:options.read_temporary_file + let l:chain_with = a:options.chain_with + + if empty(l:command) + " If there's nothing further to chain the command with, stop here. + if l:chain_with is v:null + return 0 + endif + + " If there's another chained callback to run, then run that. + call s:RunFixer({ + \ 'buffer': l:buffer, + \ 'input': l:input, + \ 'callback_index': a:options.callback_index, + \ 'callback_list': a:options.callback_list, + \ 'chain_callback': l:chain_with, + \ 'output': [], + \}) + + return 1 + endif let [l:temporary_file, l:command] = ale#command#FormatCommand(l:buffer, l:command, 1) call s:CreateTemporaryFileForJob(l:buffer, l:temporary_file, l:input) @@ -186,8 +216,9 @@ function! s:RunJob(options) abort \ 'buffer': l:buffer, \ 'input': l:input, \ 'output': [], - \ 'callback_list': a:options.callback_list, + \ 'chain_with': l:chain_with, \ 'callback_index': a:options.callback_index, + \ 'callback_list': a:options.callback_list, \} if l:read_temporary_file @@ -250,13 +281,24 @@ function! s:RunFixer(options) abort let l:buffer = a:options.buffer let l:input = a:options.input let l:index = a:options.callback_index + let l:chain_callback = get(a:options, 'chain_callback', v:null) while len(a:options.callback_list) > l:index - let l:Function = a:options.callback_list[l:index] - - let l:result = ale#util#FunctionArgCount(l:Function) == 1 - \ ? call(l:Function, [l:buffer]) - \ : call(l:Function, [l:buffer, copy(l:input)]) + let l:Function = l:chain_callback isnot v:null + \ ? ale#util#GetFunction(l:chain_callback) + \ : a:options.callback_list[l:index] + + if l:chain_callback isnot v:null + " Chained commands accept (buffer, output, [input]) + let l:result = ale#util#FunctionArgCount(l:Function) == 2 + \ ? call(l:Function, [l:buffer, a:options.output]) + \ : call(l:Function, [l:buffer, a:options.output, copy(l:input)]) + else + " Chained commands accept (buffer, [input]) + let l:result = ale#util#FunctionArgCount(l:Function) == 1 + \ ? call(l:Function, [l:buffer]) + \ : call(l:Function, [l:buffer, copy(l:input)]) + endif if type(l:result) == type(0) && l:result == 0 " When `0` is returned, skip this item. @@ -271,6 +313,7 @@ function! s:RunFixer(options) abort \ 'input': l:input, \ 'output_stream': get(l:result, 'output_stream', 'stdout'), \ 'read_temporary_file': get(l:result, 'read_temporary_file', 0), + \ 'chain_with': get(l:result, 'chain_with', v:null), \ 'callback_list': a:options.callback_list, \ 'callback_index': l:index, \}) -- cgit v1.2.3