# HG changeset patch # User Pierre-Yves David # Date 2019-11-21 16:54:25 # Node ID 8e2df30694de65740d08d535f19dc7f08dee8d9f # Parent b7d0aa525435e435ac5094ffbbdb0f944b6cfcc5 localrepo: extract handling of some special value in __getitem__ The value "tip" should always be accessible, otherwise there is some problematic bug in the lower level. So we can access this outside of the general try/catch. If it fails some wider and actual big is in play. Differential Revision: https://phab.mercurial-scm.org/D7475 diff --git a/mercurial/localrepo.py b/mercurial/localrepo.py --- a/mercurial/localrepo.py +++ b/mercurial/localrepo.py @@ -1533,14 +1533,16 @@ class localrepository(object): # dealing with some special values if changeid == b'null': return context.changectx(self, nullrev, nullid) + if changeid == b'tip': + node = self.changelog.tip() + rev = self.changelog.rev(node) + return context.changectx(self, rev, node) + # dealing with arbitrary values try: if isinstance(changeid, int): node = self.changelog.node(changeid) rev = changeid - elif changeid == b'tip': - node = self.changelog.tip() - rev = self.changelog.rev(node) elif changeid == b'.': # this is a hack to delay/avoid loading obsmarkers # when we know that '.' won't be hidden