[PATCH 06 of 10] revset: add support for p2(wdir()) to get second parent of working directory

Pulkit Goyal 7895pulkit at gmail.com
Mon May 22 16:52:16 EDT 2017


# HG changeset patch
# User Pulkit Goyal <7895pulkit at gmail.com>
# Date 1495399462 -19800
#      Mon May 22 02:14:22 2017 +0530
# Node ID b358980b7e88e2aafb79eefd456fe8c492d013ec
# Parent  05143c5cb16a9e50b40321d5417e0c91ba6afb16
revset: add support for p2(wdir()) to get second parent of working directory

This adds support for finding the second parent of working directory using the
p2 predicate.

diff --git a/mercurial/revset.py b/mercurial/revset.py
--- a/mercurial/revset.py
+++ b/mercurial/revset.py
@@ -1434,7 +1434,12 @@
     ps = set()
     cl = repo.changelog
     for r in getset(repo, fullreposet(repo), x):
-        ps.add(cl.parentrevs(r)[1])
+        try:
+            ps.add(cl.parentrevs(r)[1])
+        except error.WdirUnsupported:
+            parents = repo[r].parents()
+            if len(parents) == 2:
+                ps.add(parents[1])
     ps -= {node.nullrev}
     # XXX we should turn this into a baseset instead of a set, smartset may do
     # some optimizations from the fact this is a baseset.
diff --git a/tests/test-revset.t b/tests/test-revset.t
--- a/tests/test-revset.t
+++ b/tests/test-revset.t
@@ -1233,6 +1233,7 @@
   2147483647
   $ hg debugrevspec 'p1(wdir())'
   7
+  $ hg debugrevspec 'p2(wdir())'
   $ hg debugrevspec 'parents(wdir())'
   7
   $ hg debugrevspec 'wdir()^1'


More information about the Mercurial-devel mailing list