Mercurial > hg
diff mercurial/localrepo.py @ 24373:59cc09240afb
revbranchcache: move out of branchmap onto localrepo
Previously the revbranchcache was a field inside the branchmap. This is bad for
a couple reasons:
1) There can be multiple branchmaps per repo (one for each filter level). There
can only be one revbranchcache per repo. In fact, a revbranchcache could only
exist on a branchmap that was for the unfiltered view, so you could have
branchmaps exist for which you couldn't have a revbranchcache. It was funky.
2) The write lifecycle for the revbranchcache is going to be different from
the branchmap (branchmap is greedily written early on, revbranchcache
should be lazily computed and written).
This patch moves the revbranchcache to live as a field on the localrepo
(alongside self._branchmap). This will allow us to handle it's lifecycle
differently, which will let us move it to be lazily computed in future patches.
author | Durham Goode <durham@fb.com> |
---|---|
date | Tue, 10 Feb 2015 19:53:48 -0800 |
parents | b9f7f3eeb99c |
children | 9347c15d8136 |
line wrap: on
line diff
--- a/mercurial/localrepo.py Tue Mar 17 14:29:56 2015 -0700 +++ b/mercurial/localrepo.py Tue Feb 10 19:53:48 2015 -0800 @@ -279,6 +279,7 @@ self._branchcaches = {} + self._revbranchcache = None self.filterpats = {} self._datafilters = {} self._transref = self._lockref = self._wlockref = None @@ -726,6 +727,12 @@ branchmap.updatecache(self) return self._branchcaches[self.filtername] + @unfilteredmethod + def revbranchcache(self): + if not self._revbranchcache: + self._revbranchcache = branchmap.revbranchcache(self.unfiltered()) + return self._revbranchcache + def branchtip(self, branch, ignoremissing=False): '''return the tip node for a given branch