# HG changeset patch # User Pierre-Yves David # Date 2024-03-06 15:10:44 # Node ID 767b62cb728e1af79ab5a23dce643529a35fe547 # Parent 50850689d3c03117e9de948429f862643081b3e7 branchcache: gather newly closed head in a dedicated set This is part of a series to more clearly split the update in two step. This will allow us to introduce a fast path during update in a future changeset. diff --git a/mercurial/branchmap.py b/mercurial/branchmap.py --- a/mercurial/branchmap.py +++ b/mercurial/branchmap.py @@ -288,6 +288,7 @@ class _BaseBranchCache: obsrevs = obsolete.getrevs(repo, b'obsolete') # collect new branch entries newbranches = {} + new_closed = set() obs_ignored = set() getbranchinfo = repo.revbranchcache().branchinfo max_rev = -1 @@ -301,7 +302,7 @@ class _BaseBranchCache: branch, closesbranch = getbranchinfo(r) newbranches.setdefault(branch, []).append(r) if closesbranch: - self._closednodes.add(cl.node(r)) + new_closed.add(r) if max_rev < 0: msg = "running branchcache.update without revision to update" raise error.ProgrammingError(msg) @@ -391,6 +392,8 @@ class _BaseBranchCache: if bheadset: self[branch] = [cl.node(rev) for rev in sorted(bheadset)] + self._closednodes.update(cl.node(rev) for rev in new_closed) + duration = util.timer() - starttime repo.ui.log( b'branchcache',