Extract :Gsplit! implementation
This commit is contained in:
parent
a50e072587
commit
20bdfee4b7
@ -1956,12 +1956,12 @@ augroup END
|
|||||||
call s:command("-bang -nargs=? -range=-1 -complete=customlist,fugitive#CompleteGit Git", "Git")
|
call s:command("-bang -nargs=? -range=-1 -complete=customlist,fugitive#CompleteGit Git", "Git")
|
||||||
|
|
||||||
function! s:GitCommand(line1, line2, range, count, bang, mods, reg, arg, args) abort
|
function! s:GitCommand(line1, line2, range, count, bang, mods, reg, arg, args) abort
|
||||||
if a:bang
|
|
||||||
return s:Open('edit', 1, a:mods, a:arg, a:args)
|
|
||||||
endif
|
|
||||||
let dir = s:Dir()
|
let dir = s:Dir()
|
||||||
let tree = s:Tree(dir)
|
let tree = s:Tree(dir)
|
||||||
let [args, after] = s:ShellExpandChain(a:arg, tree)
|
let [args, after] = s:SplitExpandChain(a:arg, tree)
|
||||||
|
if a:bang
|
||||||
|
return s:OpenExec('edit', a:mods, args, dir) . after
|
||||||
|
endif
|
||||||
let git = s:UserCommand(dir)
|
let git = s:UserCommand(dir)
|
||||||
if has('gui_running') && !has('win32')
|
if has('gui_running') && !has('win32')
|
||||||
let git .= ' --no-pager'
|
let git .= ' --no-pager'
|
||||||
@ -1969,7 +1969,7 @@ function! s:GitCommand(line1, line2, range, count, bang, mods, reg, arg, args) a
|
|||||||
if has('nvim') && executable('env')
|
if has('nvim') && executable('env')
|
||||||
let git = 'env GIT_TERMINAL_PROMPT=0 ' . git
|
let git = 'env GIT_TERMINAL_PROMPT=0 ' . git
|
||||||
endif
|
endif
|
||||||
let cmd = "exe '!'.escape(" . string(git . ' ' . args) . ",'!#%')"
|
let cmd = "exe '!'.escape(" . string(git . ' ' . s:shellesc(args)) . ",'!#%')"
|
||||||
return cmd . after
|
return cmd . after
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
@ -3367,28 +3367,30 @@ function! s:BlurStatus() abort
|
|||||||
endif
|
endif
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
function! s:Open(cmd, bang, mods, arg, args) abort
|
function! s:OpenExec(cmd, mods, args, ...) abort
|
||||||
let mods = s:Mods(a:mods)
|
let dir = s:Dir(a:0 ? a:1 : -1)
|
||||||
|
let args = s:shellesc(a:args)
|
||||||
|
let temp = tempname()
|
||||||
|
let git = s:UserCommand(dir)
|
||||||
|
silent! execute '!' . escape(git . ' --no-pager ' . args, '!#%') .
|
||||||
|
\ (&shell =~# 'csh' ? ' >& ' . temp : ' > ' . temp . ' 2>&1')
|
||||||
|
redraw!
|
||||||
|
let temp = s:Resolve(temp)
|
||||||
|
let s:temp_files[s:cpath(temp)] = { 'dir': dir, 'filetype': 'git' }
|
||||||
|
if a:cmd ==# 'edit'
|
||||||
|
call s:BlurStatus()
|
||||||
|
endif
|
||||||
|
silent execute s:Mods(a:mods) . a:cmd temp
|
||||||
|
call fugitive#ReloadStatus(dir, 1)
|
||||||
|
return 'echo ' . string(':!' . git . ' ' . args)
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
function! s:Open(cmd, bang, mods, arg, args) abort
|
||||||
if a:bang
|
if a:bang
|
||||||
let dir = s:Dir()
|
return s:OpenExec(a:cmd, a:mods, s:SplitExpand(a:arg, s:Tree()))
|
||||||
let tree = s:Tree(dir)
|
|
||||||
let temp = tempname()
|
|
||||||
let git = s:UserCommand(dir)
|
|
||||||
let args = s:ShellExpand(a:arg, tree)
|
|
||||||
silent! execute '!' . escape(git . ' --no-pager ' . args, '!#%') .
|
|
||||||
\ (&shell =~# 'csh' ? ' >& ' . temp : ' > ' . temp . ' 2>&1')
|
|
||||||
redraw!
|
|
||||||
let temp = s:Resolve(temp)
|
|
||||||
let s:temp_files[s:cpath(temp)] = { 'dir': s:Dir(), 'filetype': 'git' }
|
|
||||||
if a:cmd ==# 'edit'
|
|
||||||
call s:BlurStatus()
|
|
||||||
endif
|
|
||||||
silent execute mods . a:cmd temp
|
|
||||||
call fugitive#ReloadStatus(dir, 1)
|
|
||||||
return 'echo ' . string(':!' . git . ' ' . args)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
let mods = s:Mods(a:mods)
|
||||||
try
|
try
|
||||||
let [file, pre] = s:OpenParse(a:args)
|
let [file, pre] = s:OpenParse(a:args)
|
||||||
let file = s:Generate(file)
|
let file = s:Generate(file)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user