Mercurial > evolve
view hgext3rd/topic/revset.py @ 2686:fc3a66ad635b
compat: fix topicset for mercurial 4.1
The 'getrevset' method is not available there.
author | Boris Feld <boris.feld@octobus.net> |
---|---|
date | Thu, 29 Jun 2017 18:22:06 +0200 |
parents | a6e3c2fcb1d7 |
children | 96843c68acc8 |
line wrap: on
line source
from __future__ import absolute_import from mercurial import ( revset, util, ) from . import ( constants, destination, stack, ) try: mkmatcher = revset._stringmatcher except AttributeError: mkmatcher = util.stringmatcher def topicset(repo, subset, x): """`topic([topic])` Specified topic or all changes with any topic specified. If `topic` starts with `re:` the remainder of the name is treated as a regular expression. TODO: make `topic(revset)` work the same as `branch(revset)`. """ args = revset.getargs(x, 0, 1, 'topic takes one or no arguments') if args: # match a specific topic topic = revset.getstring(args[0], 'topic() argument must be a string') if topic == '.': topic = repo['.'].extra().get('topic', '') _kind, _pattern, matcher = mkmatcher(topic) else: matcher = lambda t: bool(t) # XXX-mercurial 4.1 compat # otherwise use: # # mutable = repo._phasecache.getrevset(repo, (phases.draft, phases.secret)) # mutable = set() for u in repo._phasecache._phasesets[1:]: mutable.update(u) mutable = revset.baseset(mutable - repo.changelog.filteredrevs) mutable.sort() rawchange = repo.changelog.changelogrevision key = constants.extrakey def matchtopic(r): topic = rawchange(r).extra.get(key) if topic is None: return False return matcher(topic) return (subset & mutable).filter(matchtopic) def ngtipset(repo, subset, x): """`ngtip([branch])` The untopiced tip. Name is horrible so that people change it. """ args = revset.getargs(x, 1, 1, 'topic takes one') # match a specific topic branch = revset.getstring(args[0], 'ngtip() argument must be a string') if branch == '.': branch = repo['.'].branch() return subset & revset.baseset(destination.ngtip(repo, branch)) def stackset(repo, subset, x): """`stack()` All relevant changes in the current topic, This is roughly equivalent to 'topic(.) - obsolete' with a sorting moving unstable changeset after there future parent (as if evolve where already run).""" err = 'stack() takes no argument, it works on current topic' revset.getargs(x, 0, 0, err) topic = repo.currenttopic topic = None branch = None if not topic and repo.currenttopic: topic = repo.currenttopic if not topic: branch = repo[None].branch() return revset.baseset(stack.getstack(repo, branch=branch, topic=topic)) & subset def modsetup(ui): revset.symbols.update({'topic': topicset}) revset.symbols.update({'ngtip': ngtipset}) revset.symbols.update({'stack': stackset})