# HG changeset patch # User Yuya Nishihara # Date 1492221077 -32400 # Node ID 2ab7578e685b43ad3edaa9104acd8221368472a3 # Parent 3920b5970f956ab9d3668bdeb0df821e674ef8d4 templatefilters: fix crash by string formatting of '{x|splitlines}' Before, it crashed because mapping['templ'] was missing. As it didn't support the legacy list template from the beginning, we can simply use hybridlist(). diff -r 3920b5970f95 -r 2ab7578e685b mercurial/templatefilters.py --- a/mercurial/templatefilters.py Wed Apr 05 21:57:05 2017 +0900 +++ b/mercurial/templatefilters.py Sat Apr 15 10:51:17 2017 +0900 @@ -339,7 +339,7 @@ @templatefilter('splitlines') def splitlines(text): """Any text. Split text into a list of lines.""" - return templatekw.showlist('line', text.splitlines(), {}, plural='lines') + return templatekw.hybridlist(text.splitlines(), name='line') @templatefilter('stringescape') def stringescape(text): diff -r 3920b5970f95 -r 2ab7578e685b tests/test-command-template.t --- a/tests/test-command-template.t Wed Apr 05 21:57:05 2017 +0900 +++ b/tests/test-command-template.t Sat Apr 15 10:51:17 2017 +0900 @@ -3894,6 +3894,11 @@ o foo line 1 foo line 2 + $ hg log -R a -r0 -T '{desc|splitlines}\n' + line 1 line 2 + $ hg log -R a -r0 -T '{join(desc|splitlines, "|")}\n' + line 1|line 2 + Test startswith $ hg log -Gv -R a --template "{startswith(desc)}" hg: parse error: startswith expects two arguments