mercurial/obsolete.py
changeset 17213 7eb5aa1f83fd
parent 17200 19f5dec2d61f
child 17219 494a970f68de
--- a/mercurial/obsolete.py	Tue Jul 17 18:14:16 2012 +0200
+++ b/mercurial/obsolete.py	Tue Jul 17 17:31:29 2012 +0200
@@ -285,3 +285,17 @@
     for data in ctx._repo.obsstore.successors.get(ctx.node(), ()):
         yield marker(ctx._repo, data)
 
+def anysuccessors(obsstore, node):
+    """Yield every successor of <node>
+
+    This this a linear yield unsuitable to detect splitted changeset."""
+    remaining = set([node])
+    seen = set(remaining)
+    while remaining:
+        current = remaining.pop()
+        yield current
+        for mark in obsstore.precursors.get(current, ()):
+            for suc in mark[1]:
+                if suc not in seen:
+                    seen.add(suc)
+                    remaining.add(suc)