mercurial/commands.py
changeset 45697 494642ed3c50
parent 45696 de6f2afc0247
child 45698 41e0cbccb260
--- a/mercurial/commands.py	Wed Sep 09 15:23:49 2020 +0900
+++ b/mercurial/commands.py	Wed Sep 09 15:56:40 2020 +0900
@@ -3398,9 +3398,11 @@
     if opts.get(b'print0'):
         sep = eol = b'\0'
 
-    getfile = util.lrucachefunc(repo.file)
-    matches = {}
-    copies = {}
+    searcher = grepmod.grepsearcher(ui, repo, regexp)
+
+    getfile = searcher._getfile
+    matches = searcher._matches
+    copies = searcher._copies
 
     def grepbody(fn, rev, body):
         matches[rev].setdefault(fn, [])
@@ -3520,12 +3522,12 @@
             fm.data(matched=False)
         fm.end()
 
-    skip = set()
-    revfiles = {}
+    skip = searcher._skip
+    revfiles = searcher._revfiles
     found = False
     follow = opts.get(b'follow')
 
-    getrenamed = scmutil.getrenamedfn(repo)
+    getrenamed = searcher._getrenamed
 
     def readfile(ctx, fn):
         rev = ctx.rev()