Mercurial > hg
changeset 31926:932241b8c644
templater: add dict() constructor
It's troublesome to build JSON by template, so let's add programmatic way.
author | Yuya Nishihara <yuya@tcha.org> |
---|---|
date | Mon, 03 Apr 2017 22:54:06 +0900 |
parents | 5b2241e84982 |
children | 2abc556dbe92 |
files | mercurial/templater.py tests/test-command-template.t |
diffstat | 2 files changed, 24 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- 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
--- 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'