Mercurial > evolve
view hgext3rd/topic/revset.py @ 2670:f5d52fa1cd55
topic: move the heads data to the branch line when appropriates
The topic line is dropped as it is quite confusing.
author | Pierre-Yves David <pierre-yves.david@octobus.net> |
---|---|
date | Wed, 28 Jun 2017 01:53:21 +0200 |
parents | b933a8068c17 |
children | aa4db71a6224 |
line wrap: on
line source
from __future__ import absolute_import from mercurial.i18n import _ from mercurial import ( error, phases, 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) mutable = repo._phasecache.getrevset(repo, (phases.draft, phases.secret)) 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).""" topic = repo.currenttopic if not topic: raise error.Abort(_('no active topic to list')) # ordering hack, boo 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})