Provide option for status reloading

Closes https://github.com/tpope/vim-fugitive/issues/1209
This commit is contained in:
Tim Pope 2019-02-21 13:20:36 -05:00
parent 8caa4a0ba3
commit 28a03d0b00

View File

@ -1822,7 +1822,7 @@ function! s:Git(bang, mods, args) abort
let args = matchstr(a:args,'\v\C.{-}%($|\\@<!%(\\\\)*\|)@=') let args = matchstr(a:args,'\v\C.{-}%($|\\@<!%(\\\\)*\|)@=')
let after = matchstr(a:args, '\v\C\\@<!%(\\\\)*\zs\|.*') let after = matchstr(a:args, '\v\C\\@<!%(\\\\)*\zs\|.*')
let tree = s:Tree() let tree = s:Tree()
if has('win32') if !s:CanAutoReloadStatus()
let after = '|call fugitive#ReloadStatus()' . after let after = '|call fugitive#ReloadStatus()' . after
endif endif
if exists(':terminal') && has('nvim') && !get(g:, 'fugitive_force_bang_command') if exists(':terminal') && has('nvim') && !get(g:, 'fugitive_force_bang_command')
@ -1899,15 +1899,6 @@ call s:command("-bar -bang -nargs=? -complete=customlist,s:DirComplete Glcd :exe
call s:command("-bar -bang -range=-1 Gstatus :execute s:Status(<bang>0, <count>, '<mods>')") call s:command("-bar -bang -range=-1 Gstatus :execute s:Status(<bang>0, <count>, '<mods>')")
call s:command("-bar -bang -range=-1 G :execute s:Status(<bang>0, <count>, '<mods>')") call s:command("-bar -bang -range=-1 G :execute s:Status(<bang>0, <count>, '<mods>')")
augroup fugitive_status
autocmd!
if !has('win32')
autocmd ShellCmdPost * call fugitive#ReloadStatus()
autocmd QuickFixCmdPost c*ile call fugitive#ReloadStatus()
autocmd FocusGained * call fugitive#ReloadStatus()
autocmd BufDelete term://* call fugitive#ReloadStatus()
endif
augroup END
function! s:Status(bang, count, mods) abort function! s:Status(bang, count, mods) abort
try try
@ -2043,6 +2034,24 @@ function! fugitive#ReloadStatus(...) abort
endtry endtry
endfunction endfunction
function! s:CanAutoReloadStatus() abort
return get(g:, 'fugitive_autoreload_status', !has('win32'))
endfunction
function! s:AutoReloadStatus(...) abort
if s:CanAutoReloadStatus()
return call('fugitive#ReloadStatus', a:000)
endif
endfunction
augroup fugitive_status
autocmd!
autocmd ShellCmdPost * call s:AutoReloadStatus()
autocmd QuickFixCmdPost c*file call s:AutoReloadStatus()
autocmd FocusGained * call s:AutoReloadStatus()
autocmd BufDelete term://* call s:AutoReloadStatus()
augroup END
function! s:StageInfo(...) abort function! s:StageInfo(...) abort
let lnum = a:0 ? a:1 : line('.') let lnum = a:0 ? a:1 : line('.')
let sigil = matchstr(getline(lnum), '^[ @\+-]') let sigil = matchstr(getline(lnum), '^[ @\+-]')