Speed up :Ggrep
This commit is contained in:
parent
a1b78969f5
commit
469a73f3d9
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user