6 Commits

Author SHA1 Message Date
Michael van der Kamp
540b6a8b8a Merge 32e2cd9e47 into 174230d6a7 2025-01-02 19:38:43 +01:00
Michael van der Kamp
32e2cd9e47 Cache results from git ls-files
Only support stage '0' for tree objects
2021-11-14 11:46:22 -06:00
Michael van der Kamp
d5edbd75d8 Report info for the correct stage 2021-11-14 11:45:45 -06:00
Michael van der Kamp
0101f49718 Let PathInfo decide how to fill the error entry 2021-10-30 18:07:12 -06:00
Michael van der Kamp
c7bfb8241f Extract IndexInfo() 2021-10-30 18:07:07 -06:00
Michael van der Kamp
6f06629eeb Only query requested path in stage objects 2021-10-30 18:07:07 -06:00

View File

@@ -2162,14 +2162,57 @@ function! s:TreeInfo(dir, commit) abort
return [{}, -1]
endfunction
let s:index_info = {}
function! s:IndexInfo(dir, commit_stage, path) abort
let cache_key = 'cache://' . a:dir . '//' . a:path
let index = get(s:index_info, cache_key, [])
let newftime = getftime(fugitive#Find('.git/index', a:dir))
if get(index, 0, -1) == newftime
return get(get(index, 1, {}), a:commit_stage, [])
endif
let indexes = {'0': [], '1': [], '2': [], '3': []}
let s:index_info[cache_key] = [newftime, indexes]
let result = fugitive#Execute(['--literal-pathspecs', 'ls-files', '--stage', '--', a:path])
if result.exit_status
return []
endif
for line in result.stdout[:2]
" Inspect up to the first three lines to find the correct stage
if empty(line)
break
endif
let [info, filename] = split(line, "\t")
let [mode, sha, stage] = split(info, '\s\+')
if filename ==# a:path
let indexes[stage] = [newftime, mode, 'blob', sha, -2]
else
" Only support stage '0' for tree objects
let indexes['0'] = [newftime, '040000', 'tree', '', 0]
endif
endfor
return get(indexes, a:commit_stage, [])
endfunction
function! s:PathInfo(url) abort
let [dir, commit, file] = s:DirCommitFile(a:url)
if empty(dir) || !get(g:, 'fugitive_file_api', 1)
return [-1, '000000', '', '', -1]
endif
let path = substitute(file[1:-1], '/*$', '', '')
let [tree, ftime] = s:TreeInfo(dir, commit)
let entry = empty(path) ? [ftime, '040000', 'tree', '', -1] : get(tree, path, [])
if empty(path)
let [_, ftime] = s:TreeInfo(dir, commit)
let entry = [ftime, '040000', 'tree', '', -1]
elseif commit =~# '^:\=[0-3]$'
let entry = s:IndexInfo(dir, commit[-1:-1], path)
else
let [tree, ftime] = s:TreeInfo(dir, commit)
let entry = get(tree, path, [])
endif
if empty(entry) || file =~# '/$' && entry[2] !=# 'tree'
return [-1, '000000', '', '', -1]
else