# HG changeset patch # User Anton Shestakov # Date 1588092254 -28800 # Node ID 9035901412e6827eb5a35a71f9eb40184d812c29 # Parent 77a77d0f5441c809bfb173d1ad8fd2becd4b8349 topic: provide cache to successorssets() in _singlesuccessor() Since we're using obsutil.successorssets() in a loop, it may help performance to have cache. diff -r 77a77d0f5441 -r 9035901412e6 hgext3rd/topic/evolvebits.py --- a/hgext3rd/topic/evolvebits.py Wed Apr 29 00:43:13 2020 +0800 +++ b/hgext3rd/topic/evolvebits.py Wed Apr 29 00:44:14 2020 +0800 @@ -75,14 +75,15 @@ return p.rev() obs = repo[p] ui = repo.ui - newer = obsutil.successorssets(repo, obs.node()) + cache = {} + newer = obsutil.successorssets(repo, obs.node(), cache=cache) # search of a parent which is not killed while not newer: ui.debug(b"stabilize target %s is plain dead," b" trying to stabilize on its parent\n" % obs) obs = obs.p1() - newer = obsutil.successorssets(repo, obs.node()) + newer = obsutil.successorssets(repo, obs.node(), cache=cache) if 1 < len(newer): # divergence case # we should pick as arbitrary one