mirror of
https://github.com/tpope/vim-fugitive.git
synced 2025-11-18 08:13:44 -05:00
Merge 07de0b8d9f into b068eaf1e6
This commit is contained in:
@@ -2471,6 +2471,17 @@ function! s:CompleteHeads(dir) abort
|
||||
\ sort(s:LinesError([a:dir, 'rev-parse', '--symbolic', '--branches', '--tags', '--remotes'])[0])
|
||||
endfunction
|
||||
|
||||
function! s:SplitRevRange(base, pat)
|
||||
let index = matchend(a:base, a:pat)
|
||||
if index == -1
|
||||
return ['', a:base]
|
||||
endif
|
||||
let pre = a:base[:index - 1]
|
||||
let base = a:base[index:]
|
||||
return [pre, base]
|
||||
endif
|
||||
endfunction
|
||||
|
||||
function! fugitive#CompleteObject(base, ...) abort
|
||||
let dir = a:0 == 1 ? a:1 : a:0 >= 3 ? a:3 : s:Dir()
|
||||
let tree = s:Tree(dir)
|
||||
@@ -2480,9 +2491,10 @@ function! fugitive#CompleteObject(base, ...) abort
|
||||
let subdir = strpart(cwd, len(tree) + 1) . '/'
|
||||
endif
|
||||
let base = s:Expand(a:base)
|
||||
let [pre, base] = s:SplitRevRange(base, '^[^:]*\/\@<!\.\.\.\=[\/\.]\@!')
|
||||
|
||||
if a:base =~# '^!\d*$' && base !~# '^!'
|
||||
return [base]
|
||||
return [pre . base]
|
||||
elseif base =~# '^\.\=/\|^:(' || base !~# ':'
|
||||
let results = []
|
||||
if base =~# '^refs/'
|
||||
@@ -2498,6 +2510,7 @@ function! fugitive#CompleteObject(base, ...) abort
|
||||
let results += s:FilterEscape(heads, fnameescape(base))
|
||||
endif
|
||||
let results += a:0 == 1 || a:0 >= 3 ? fugitive#CompletePath(base, 0, '', dir, a:0 >= 4 ? a:4 : tree) : fugitive#CompletePath(base)
|
||||
let results = map(results, 'pre . v:val')
|
||||
return results
|
||||
|
||||
elseif base =~# '^:'
|
||||
@@ -2517,7 +2530,7 @@ function! fugitive#CompleteObject(base, ...) abort
|
||||
call map(entries,'s:sub(v:val,"^04.*\\zs$","/")')
|
||||
call map(entries,'parent.s:sub(v:val,".*\t","")')
|
||||
endif
|
||||
return s:FilterEscape(entries, fnameescape(base))
|
||||
return map(s:FilterEscape(entries, fnameescape(base)), 'pre . v:val')
|
||||
endfunction
|
||||
|
||||
function! s:CompleteSub(subcommand, A, L, P, ...) abort
|
||||
|
||||
Reference in New Issue
Block a user