Encapsulate "-z" null splitting
This commit is contained in:
parent
39087fed59
commit
cf5b43443f
@ -340,6 +340,11 @@ function! s:LinesError(...) abort
|
|||||||
return [len(out) && !exec_error ? split(out, "\n", 1) : [], exec_error]
|
return [len(out) && !exec_error ? split(out, "\n", 1) : [], exec_error]
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
function! s:NullError(...) abort
|
||||||
|
let [out, exec_error] = s:SystemError(call('fugitive#Prepare', a:000))
|
||||||
|
return [exec_error ? [] : split(out, "\1"), exec_error ? out : '', exec_error]
|
||||||
|
endfunction
|
||||||
|
|
||||||
function! s:TreeChomp(...) abort
|
function! s:TreeChomp(...) abort
|
||||||
let cmd = call('fugitive#Prepare', a:000)
|
let cmd = call('fugitive#Prepare', a:000)
|
||||||
let [out, exec_error] = s:SystemError(cmd)
|
let [out, exec_error] = s:SystemError(cmd)
|
||||||
@ -407,8 +412,8 @@ function! fugitive#Config(...) abort
|
|||||||
let dict = s:config[key][1]
|
let dict = s:config[key][1]
|
||||||
else
|
else
|
||||||
let dict = {}
|
let dict = {}
|
||||||
let lines = split(system(FugitivePrepare(['config', '--list', '-z'], dir)), "\1")
|
let [lines, message, exec_error] = s:NullError([dir, 'config', '--list', '-z'])
|
||||||
if v:shell_error
|
if exec_error
|
||||||
return {}
|
return {}
|
||||||
endif
|
endif
|
||||||
for line in lines
|
for line in lines
|
||||||
@ -1434,9 +1439,9 @@ function! fugitive#BufReadStatus() abort
|
|||||||
let cmd += ['-c', 'GIT_INDEX_FILE=' . amatch]
|
let cmd += ['-c', 'GIT_INDEX_FILE=' . amatch]
|
||||||
endif
|
endif
|
||||||
let cmd += ['status', '--porcelain', '-bz']
|
let cmd += ['status', '--porcelain', '-bz']
|
||||||
let output = split(system(fugitive#Prepare(cmd)), "\1")
|
let [output, message, exec_error] = s:NullError(cmd)
|
||||||
if v:shell_error
|
if exec_error
|
||||||
throw 'fugitive: ' . join(output, ' ')
|
throw 'fugitive: ' . message
|
||||||
endif
|
endif
|
||||||
|
|
||||||
let head = matchstr(output[0], '^## \zs\S\+\ze\%($\| \[\)')
|
let head = matchstr(output[0], '^## \zs\S\+\ze\%($\| \[\)')
|
||||||
@ -1902,8 +1907,8 @@ let s:aliases = {}
|
|||||||
function! s:Aliases(dir) abort
|
function! s:Aliases(dir) abort
|
||||||
if !has_key(s:aliases, a:dir)
|
if !has_key(s:aliases, a:dir)
|
||||||
let s:aliases[a:dir] = {}
|
let s:aliases[a:dir] = {}
|
||||||
let lines = split(s:System(fugitive#Prepare('config','-z','--get-regexp','^alias[.]')),"\1")
|
let lines = s:NullError([a:dir, 'config', '-z', '--get-regexp', '^alias[.]'])[0]
|
||||||
for line in v:shell_error ? [] : lines
|
for line in lines
|
||||||
let s:aliases[a:dir][matchstr(line, '\.\zs.\{-}\ze\n')] = matchstr(line, '\n\zs.*')
|
let s:aliases[a:dir][matchstr(line, '\.\zs.\{-}\ze\n')] = matchstr(line, '\n\zs.*')
|
||||||
endfor
|
endfor
|
||||||
endif
|
endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user