# HG changeset patch # User Yuya Nishihara # Date 1491227646 -32400 # Node ID 932241b8c6446efbccb88d164c2b8c5b1cc81f8c # Parent 5b2241e849822bf3fefd4de88531e2407f3fcd9d templater: add dict() constructor It's troublesome to build JSON by template, so let's add programmatic way. diff -r 5b2241e84982 -r 932241b8c644 mercurial/templater.py --- a/mercurial/templater.py Wed Apr 05 22:28:09 2017 +0900 +++ b/mercurial/templater.py Mon Apr 03 22:54:06 2017 +0900 @@ -532,6 +532,14 @@ # i18n: "date" is a keyword raise error.ParseError(_("date expects a date information")) +@templatefunc('dict([key=value...])', argspec='**kwargs') +def dict_(context, mapping, args): + """Construct a dict from key-value pairs.""" + data = util.sortdict() + data.update((k, evalfuncarg(context, mapping, v)) + for k, v in args['kwargs'].iteritems()) + return templatekw.hybriddict(data) + @templatefunc('diff([includepattern [, excludepattern]])') def diff(context, mapping, args): """Show a diff, optionally diff -r 5b2241e84982 -r 932241b8c644 tests/test-command-template.t --- a/tests/test-command-template.t Wed Apr 05 22:28:09 2017 +0900 +++ b/tests/test-command-template.t Mon Apr 03 22:54:06 2017 +0900 @@ -3404,6 +3404,22 @@ $ hg log -r 0 --template '{if(branches, "yes", "no")}\n' no +Test dict constructor: + + $ hg log -r 0 -T '{dict(y=node|short, x=rev)}\n' + y=f7769ec2ab97 x=0 + $ hg log -r 0 -T '{dict(x=rev, y=node|short) % "{key}={value}\n"}' + x=0 + y=f7769ec2ab97 + $ hg log -r 0 -T '{dict(x=rev, y=node|short)|json}\n' + {"x": 0, "y": "f7769ec2ab97"} + $ hg log -r 0 -T '{dict()|json}\n' + {} + + $ hg log -r 0 -T '{dict(x=rev, x=node)}' + hg: parse error: dict got multiple values for keyword argument 'x' + [255] + Test get function: $ hg log -r 0 --template '{get(extras, "branch")}\n'