# HG changeset patch # User Martin von Zweigbergk # Date 2019-01-18 19:10:30 # Node ID 64bd6611e18ecf808afc6afc84bcfca94da24499 # Parent bdb5fef5cff4aca5fdc15f7494ac49a8142a0d1f grep: use set instead of dict with dummy value Differential Revision: https://phab.mercurial-scm.org/D5633 diff --git a/mercurial/commands.py b/mercurial/commands.py --- a/mercurial/commands.py +++ b/mercurial/commands.py @@ -2925,7 +2925,7 @@ def grep(ui, repo, pattern, *pats, **opt fm.data(matched=False) fm.end() - skip = {} + skip = set() revfiles = {} match = scmutil.match(repo[None], pats, opts) found = False @@ -2954,7 +2954,7 @@ def grep(ui, repo, pattern, *pats, **opt if copy: copies.setdefault(rev, {})[fn] = copy if fn in skip: - skip[copy] = True + skip.add(copy) continue files.append(fn) @@ -2983,16 +2983,16 @@ def grep(ui, repo, pattern, *pats, **opt copy = copies.get(rev, {}).get(fn) if fn in skip: if copy: - skip[copy] = True + skip.add(copy) continue pstates = matches.get(parent, {}).get(copy or fn, []) if pstates or states: r = display(fm, fn, ctx, pstates, states) found = found or r if r and not diff and not all_files: - skip[fn] = True + skip.add(fn) if copy: - skip[copy] = True + skip.add(copy) del revfiles[rev] # We will keep the matches dict for the duration of the window # clear the matches dict once the window is over