Mercurial > hg-stable
changeset 20662:a54c0d830499 stable
templater: apply "stringify()" on sub expression to get string correctly
Templating syntax allows nested expression to be specified as parts
below, but they are evaluated as a generator and don't work correctly.
- 'sep' of 'join(list, sep)'
- 'text' and 'chars' of 'strip(text, chars)'
In the former case, 'sep' returns expected string only for the first
separation, and empty one for the second or later, because the
generator has only one element.
In the latter case, templating is aborted by exception, because the
generator doesn't have 'strip()' method (as 'text') and can't be
passed as the argument to 'str.strip()' (as 'chars').
This patch applies "stringify()" on these sub expression to get string
correctly.
author | FUJIWARA Katsunori <foozy@lares.dti.ne.jp> |
---|---|
date | Mon, 10 Mar 2014 01:01:43 +0900 |
parents | 7e627fe63e5e |
children | 5ab28a2e9962 |
files | mercurial/templater.py tests/test-command-template.t |
diffstat | 2 files changed, 12 insertions(+), 3 deletions(-) [+] |
line wrap: on
line diff
--- a/mercurial/templater.py Mon Mar 10 01:01:42 2014 +0900 +++ b/mercurial/templater.py Mon Mar 10 01:01:43 2014 +0900 @@ -296,7 +296,7 @@ joiner = " " if len(args) > 1: - joiner = args[1][0](context, mapping, args[1][1]) + joiner = stringify(args[1][0](context, mapping, args[1][1])) first = True for x in joinset: @@ -328,9 +328,9 @@ if not (1 <= len(args) <= 2): raise error.ParseError(_("strip expects one or two arguments")) - text = args[0][0](context, mapping, args[0][1]) + text = stringify(args[0][0](context, mapping, args[0][1])) if len(args) == 2: - chars = args[1][0](context, mapping, args[1][1]) + chars = stringify(args[1][0](context, mapping, args[1][1])) return text.strip(chars) return text.strip()
--- a/tests/test-command-template.t Mon Mar 10 01:01:42 2014 +0900 +++ b/tests/test-command-template.t Mon Mar 10 01:01:43 2014 +0900 @@ -1659,3 +1659,12 @@ $ hg log -r 0 --template '{if(branches, "yes", "no")}\n' no + + $ cd .. + +Test stringify on sub expressions + + $ hg log -R a -r 8 --template '{join(files, if("1", if("1", ", ")))}\n' + fourth, second, third + $ hg log -R a -r 8 --template '{strip(if("1", if("1", "-abc-")), if("1", if("1", "-")))}\n' + abc