Speed up :Ggrep

This commit is contained in:
Tim Pope 2019-07-15 20:41:33 -04:00
parent a1b78969f5
commit 469a73f3d9

View File

@ -3417,10 +3417,7 @@ function! s:LogComplete(A, L, P) abort
return s:CompleteSubcommand('log', a:A, a:L, a:P) return s:CompleteSubcommand('log', a:A, a:L, a:P)
endfunction endfunction
function! s:GrepParseLine(cached, name_only, dir, line) abort function! s:GrepParseLine(prefix, name_only, dir, line) abort
if a:line =~# '^git: \|^usage: \|^error: \|^fatal: '
return {'text': a:line}
endif
let entry = {'valid': 1} let entry = {'valid': 1}
let match = matchlist(a:line, '^\(.\{-\}\):\(\d\+\):\(\d\+:\)\=\(.*\)$') let match = matchlist(a:line, '^\(.\{-\}\):\(\d\+\):\(\d\+:\)\=\(.*\)$')
if len(match) if len(match)
@ -3428,6 +3425,8 @@ function! s:GrepParseLine(cached, name_only, dir, line) abort
let entry.lnum = +match[2] let entry.lnum = +match[2]
let entry.col = +match[3] let entry.col = +match[3]
let entry.text = match[4] let entry.text = match[4]
elseif a:line =~# '^git: \|^usage: \|^error: \|^fatal: '
return {'text': a:line}
else else
let entry.module = matchstr(a:line, '\CBinary file \zs.*\ze matches$') let entry.module = matchstr(a:line, '\CBinary file \zs.*\ze matches$')
if len(entry.module) if len(entry.module)
@ -3441,11 +3440,8 @@ function! s:GrepParseLine(cached, name_only, dir, line) abort
if empty(entry.module) if empty(entry.module)
return {'text': a:line} return {'text': a:line}
endif endif
if a:cached
let entry.module = ':0:' . entry.module
endif
if entry.module !~# ':' if entry.module !~# ':'
let entry.filename = fugitive#Find(':(top)' . entry.module, a:dir) let entry.filename = a:prefix . entry.module
else else
let entry.filename = fugitive#Find(entry.module, a:dir) let entry.filename = fugitive#Find(entry.module, a:dir)
endif endif
@ -3459,15 +3455,16 @@ function! s:Grep(type, bang, arg) abort
if fugitive#GitVersion(2, 19) if fugitive#GitVersion(2, 19)
call add(cmd, '--column') call add(cmd, '--column')
endif endif
let [args, after] = s:SplitExpandChain(a:arg, s:Tree(dir)) let tree = s:Tree(dir)
let cached = s:HasOpt(args, '--cached') let [args, after] = s:SplitExpandChain(a:arg, tree)
let prefix = s:PlatformSlash(s:HasOpt(args, '--cached') || empty(tree) ? 'fugitive://' . dir . '//0/' : tree . '/')
let name_only = s:HasOpt(args, '-l', '--files-with-matches', '--name-only', '-L', '--files-without-match') let name_only = s:HasOpt(args, '-l', '--files-with-matches', '--name-only', '-L', '--files-without-match')
let title = [listnr < 0 ? ':Ggrep' : ':Glgrep'] + args let title = [listnr < 0 ? ':Ggrep' : ':Glgrep'] + args
call s:QuickfixCreate(listnr, {'title': (listnr < 0 ? ':Ggrep ' : ':Glgrep ') . s:fnameescape(args)}) call s:QuickfixCreate(listnr, {'title': (listnr < 0 ? ':Ggrep ' : ':Glgrep ') . s:fnameescape(args)})
let tempfile = tempname() let tempfile = tempname()
exe '!' . s:shellesc(cmd + args) exe '!' . s:shellesc(cmd + args)
\ printf(&shellpipe . (&shellpipe =~# '%s' ? '' : ' %s'), s:shellesc(tempfile)) \ printf(&shellpipe . (&shellpipe =~# '%s' ? '' : ' %s'), s:shellesc(tempfile))
let list = map(readfile(tempfile), 's:GrepParseLine(cached, name_only, dir, v:val)') let list = map(readfile(tempfile), 's:GrepParseLine(prefix, name_only, dir, v:val)')
call s:QuickfixSet(listnr, list, 'a') call s:QuickfixSet(listnr, list, 'a')
if !a:bang && !empty(list) if !a:bang && !empty(list)
return (listnr < 0 ? 'c' : 'l').'first' . after return (listnr < 0 ? 'c' : 'l').'first' . after