mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 05:37:39 +03:00
util.interpolation: Support unescaped variables with more modifiers (fixes #1452)
Tests will be added in trunk.
This commit is contained in:
parent
e48914fdd7
commit
9bd711b194
1 changed files with 3 additions and 3 deletions
|
@ -32,7 +32,7 @@ local function new_render(pat, escape, funcs)
|
|||
-- assert(type(values) == "table", "bad argument #2 to 'render' (table expected)");
|
||||
return (s_gsub(template, pat, function (block)
|
||||
block = s_sub(block, 2, -2);
|
||||
local name, opt, e = s_match(block, "^([%a_][%w_.]*)(%p?)()");
|
||||
local name, raw, opt, e = s_match(block, "^([%a_][%w_.]*)(!?)(%p?)()");
|
||||
if not name then return end
|
||||
local value = values[name];
|
||||
if not value and name:find(".", 2, true) then
|
||||
|
@ -45,7 +45,7 @@ local function new_render(pat, escape, funcs)
|
|||
if funcs then
|
||||
while value ~= nil and opt == '|' do
|
||||
local f;
|
||||
f, opt, e = s_match(block, "^([%a_][%w_.]*)(%p?)()", e);
|
||||
f, raw, opt, e = s_match(block, "^([%a_][%w_.]*)(!?)(%p?)()", e);
|
||||
f = funcs[f];
|
||||
if f then value = f(value); end
|
||||
end
|
||||
|
@ -70,7 +70,7 @@ local function new_render(pat, escape, funcs)
|
|||
if type(value) ~= "string" then
|
||||
value = tostring(value);
|
||||
end
|
||||
if opt ~= '!' then
|
||||
if raw ~= '!' then
|
||||
return escape(value);
|
||||
end
|
||||
return value;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue