Mercurial > evolve
changeset 40:b9a5a596d9ef
proper computation of hidden changeset.
author | Pierre-Yves David <pierre-yves.david@logilab.fr> |
---|---|
date | Wed, 07 Sep 2011 12:42:26 +0200 |
parents | b12655157ba0 |
children | 99c131e97bb3 |
files | obsolete.py tests/test-obsolete.t |
diffstat | 2 files changed, 54 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/obsolete.py Wed Sep 07 12:09:05 2011 +0200 +++ b/obsolete.py Wed Sep 07 12:42:26 2011 +0200 @@ -9,6 +9,7 @@ from mercurial import util from mercurial import context from mercurial import revset +from mercurial import scmutil from mercurial.node import hex, bin # Patch changectx @@ -24,7 +25,14 @@ ohidden = context.changectx.hidden def hidden(ctx): - ctx._repo._obsobjrels # XXX hack to fill hiddenrevs + # hack to fill hiddenrevs + # compute hidden (XXX should move elsewhere) + if not getattr(ctx._repo.changelog, 'hiddeninit', False): + basicquery = 'obsolete() - (ancestors(not obsolete()))' + for rev in scmutil.revrange(ctx._repo, [basicquery]): + ctx._repo.changelog.hiddenrevs.add(rev) + ctx._repo.changelog.hiddeninit = True + return ohidden(ctx) context.changectx.hidden = hidden @@ -74,10 +82,6 @@ for obj in objs: objrels.setdefault(obj, set()).add(sub) - # compute hidden (XXX should move elsewhere) - for obj in objrels: - self.changelog.hiddenrevs.add(repo[obj].rev()) - # return objrels
--- a/tests/test-obsolete.t Wed Sep 07 12:09:05 2011 +0200 +++ b/tests/test-obsolete.t Wed Sep 07 12:42:26 2011 +0200 @@ -73,3 +73,48 @@ summary: add c +test obsolete changeset with no-obsolete descendant + $ hg up 1 -q + $ mkcommit "obsol_c'" # 4 (on 1) + created new head + $ hg debugobsolete 4 3 + $ hg log + changeset: 4:725c380fe99b + tag: tip + parent: 1:7c3bad9141dc + user: test + date: Thu Jan 01 00:00:00 1970 +0000 + summary: add obsol_c' + + changeset: 1:7c3bad9141dc + user: test + date: Thu Jan 01 00:00:00 1970 +0000 + summary: add b + + changeset: 0:1f0dee641bb7 + user: test + date: Thu Jan 01 00:00:00 1970 +0000 + summary: add a + + $ hg log -r 'obsolete()' --hidden + changeset: 2:4538525df7e2 + user: test + date: Thu Jan 01 00:00:00 1970 +0000 + summary: add c + + changeset: 3:0d3f46688ccc + parent: 1:7c3bad9141dc + user: test + date: Thu Jan 01 00:00:00 1970 +0000 + summary: add obsol_c + + $ hg up 3 -q + $ mkcommit d # 5 (on 3) + $ hg log -r 'obsolete()' + changeset: 3:0d3f46688ccc + parent: 1:7c3bad9141dc + user: test + date: Thu Jan 01 00:00:00 1970 +0000 + summary: add obsol_c + +