changeset 1904:f52c02bf47b7

stack: allow to refer to changeset using "t2" form hg up "t0" is seen as "update to the first changeset of my current topic". Eventually we'll drop the "t2" form in favor of the planned generic indexing operator '.{t2}'.
author Pierre-Yves David <pierre-yves.david@fb.com>
date Mon, 14 Mar 2016 18:39:19 +0000
parents 58cdf061d49a
children 3b42478ef017
files hgext3rd/topic/__init__.py hgext3rd/topic/discovery.py hgext3rd/topic/stack.py tests/test-topic-stack.t
diffstat 4 files changed, 32 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/hgext3rd/topic/__init__.py	Tue Mar 15 17:26:57 2016 +0000
+++ b/hgext3rd/topic/__init__.py	Mon Mar 14 18:39:19 2016 +0000
@@ -12,6 +12,7 @@
 """
 import functools
 import contextlib
+import re
 
 from mercurial.i18n import _
 from mercurial import branchmap
@@ -51,7 +52,22 @@
     return self.extra().get(constants.extrakey, '')
 context.basectx.topic = _contexttopic
 
+topicrev = re.compile(r'^t\d+$')
+
+
 def _namemap(repo, name):
+    if topicrev.match(name):
+        idx = int(name[1:])
+        topic = repo.currenttopic
+        if not topic:
+            raise error.Abort(_('cannot resolve "%s": no active topic') % name)
+        revs = list(stack.getstack(repo, topic))
+        try:
+            r = revs[idx]
+        except IndexError:
+            msg = _('cannot resolve "%s": topic "%s" has only %d changesets')
+            raise error.Abort(msg % (name, topic, len(revs)))
+        return [repo[r].node()]
     return [ctx.node() for ctx in
             repo.set('not public() and extra(topic, %s)', name)]
 
--- a/hgext3rd/topic/discovery.py	Tue Mar 15 17:26:57 2016 +0000
+++ b/hgext3rd/topic/discovery.py	Mon Mar 14 18:39:19 2016 +0000
@@ -107,5 +107,3 @@
     if repo.peer().capable('topics'):
         caps.append('topics')
     return caps
-
-
--- a/hgext3rd/topic/stack.py	Tue Mar 15 17:26:57 2016 +0000
+++ b/hgext3rd/topic/stack.py	Mon Mar 14 18:39:19 2016 +0000
@@ -8,7 +8,7 @@
 from mercurial import extensions
 from mercurial import obsolete
 
-def _getstack(repo, topic):
+def getstack(repo, topic):
     # XXX need sorting
     trevs = repo.revs("topic(%s) - obsolete()", topic)
     return _orderrevs(repo, trevs)
@@ -18,7 +18,7 @@
         topic = repo.currenttopic
     if not topic:
         raise error.Abort(_('no active topic to list'))
-    for idx, r in enumerate(_getstack(repo, topic)):
+    for idx, r in enumerate(getstack(repo, topic)):
         # super crude initial version
         l = "%d: %s\n" % (idx, repo[r].description().splitlines()[0])
         ui.write(l)
--- a/tests/test-topic-stack.t	Tue Mar 15 17:26:57 2016 +0000
+++ b/tests/test-topic-stack.t	Mon Mar 14 18:39:19 2016 +0000
@@ -69,12 +69,23 @@
   abort: no active topic to list
   [255]
 
+Test "t#" reference
+-------------------
+
+
+  $ hg up t1
+  abort: cannot resolve "t1": no active topic
+  [255]
+  $ hg topic foo
+  $ hg up t42
+  abort: cannot resolve "t42": topic "foo" has only 4 changesets
+  [255]
+  $ hg up t1
+  0 files updated, 0 files merged, 2 files removed, 0 files unresolved
+
 Case with some of the topic unstable
 ------------------------------------
 
-  $ hg up 'desc(c_d)'
-  switching to topic foo
-  0 files updated, 0 files merged, 2 files removed, 0 files unresolved
   $ echo bbb > ddd
   $ hg commit --amend
   $ hg log -G