# HG changeset patch # User Siddharth Agarwal # Date 2014-02-13 21:52:45 # Node ID 19b1c62cee1c83371780fa4621b8ac30f079c227 # Parent acbd19b9fbe144ebe7096a3de79897b628993176 commands.debugrevspec: add an option to print the optimized expression tree This will be used in an upcoming patch to test that the optimizer works. diff --git a/mercurial/commands.py b/mercurial/commands.py --- a/mercurial/commands.py +++ b/mercurial/commands.py @@ -2548,8 +2548,10 @@ def debugrevlog(ui, repo, file_=None, ** ui.write(('deltas against other : ') + fmt % pcfmt(numother, numdeltas)) -@command('debugrevspec', [], ('REVSPEC')) -def debugrevspec(ui, repo, expr): +@command('debugrevspec', + [('', 'optimize', None, _('print parsed tree after optimizing'))], + ('REVSPEC')) +def debugrevspec(ui, repo, expr, **opts): """parse and apply a revision specification Use --verbose to print the parsed tree before and after aliases @@ -2561,6 +2563,9 @@ def debugrevspec(ui, repo, expr): newtree = revset.findaliases(ui, tree) if newtree != tree: ui.note(revset.prettyformat(newtree), "\n") + if opts["optimize"]: + weight, optimizedtree = revset.optimize(newtree, True) + ui.note("* optimized:\n", revset.prettyformat(optimizedtree), "\n") func = revset.match(ui, expr) for c in func(repo, revset.baseset(range(len(repo)))): ui.write("%s\n" % c) diff --git a/tests/test-completion.t b/tests/test-completion.t --- a/tests/test-completion.t +++ b/tests/test-completion.t @@ -250,7 +250,7 @@ Show all commands + options debugrebuilddirstate: rev debugrename: rev debugrevlog: changelog, manifest, dump - debugrevspec: + debugrevspec: optimize debugsetparents: debugsub: rev debugsuccessorssets: