--- a/hgext3rd/topic/topicmap.py Wed Jan 30 10:03:00 2019 -0800
+++ b/hgext3rd/topic/topicmap.py Wed Nov 21 12:00:46 2018 +0000
@@ -117,7 +117,21 @@
class topiccache(_topiccache, branchmap.branchcache):
pass
branchmap.branchcache = topiccache
- extensions.wrapfunction(branchmap, 'updatecache', _wrapupdatebmcache)
+
+ try:
+ # Mercurial 4.9
+ class remotetopiccache(_topiccache, branchmap.remotebranchcache):
+ pass
+ branchmap.remotebranchcache = remotetopiccache
+
+ def _wrapupdatebmcachemethod(orig, self, repo):
+ # pass in the bound method as the original
+ return _wrapupdatebmcache(orig.__get__(self), repo)
+ extensions.wrapfunction(branchmap.BranchMapCache, 'updatecache', _wrapupdatebmcachemethod)
+ except AttributeError:
+ # Mercurial 4.8 and before
+ extensions.wrapfunction(branchmap, 'updatecache', _wrapupdatebmcache)
+
def _wrapupdatebmcache(orig, repo):
previous = getattr(repo, '_autobranchmaptopic', False)