mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.xtemplate: Adopt {-path-} syntax to strip preceding and/or trailing whitespace
Seen in some other template languages
This commit is contained in:
parent
48f26f9b98
commit
c61c78447b
2 changed files with 24 additions and 8 deletions
|
@ -8,8 +8,16 @@ local st = require("prosody.util.stanza");
|
|||
local function render(template, root, escape, filters)
|
||||
escape = escape or st.xml_escape;
|
||||
|
||||
return (s_gsub(template, "%b{}", function(block)
|
||||
return (s_gsub(template, "(%s*)(%b{})(%s*)", function(pre_blank, block, post_blank)
|
||||
local inner = s_sub(block, 2, -2);
|
||||
if inner:sub(1, 1) == "-" then
|
||||
pre_blank = "";
|
||||
inner = inner:sub(2);
|
||||
end
|
||||
if inner:sub(-1, -1) == "-" then
|
||||
post_blank = "";
|
||||
inner = inner:sub(1, -2);
|
||||
end
|
||||
local path, pipe, pos = s_match(inner, "^([^|]+)(|?)()");
|
||||
if not (type(path) == "string") then return end
|
||||
local value
|
||||
|
@ -74,12 +82,12 @@ local function render(template, root, escape, filters)
|
|||
|
||||
if type(value) == "string" then
|
||||
if not is_escaped then value = escape(value); end
|
||||
return value
|
||||
return pre_blank .. value .. post_blank
|
||||
elseif st.is_stanza(value) then
|
||||
value = value:get_text();
|
||||
if value then return escape(value) end
|
||||
if value then return pre_blank .. escape(value) .. post_blank end
|
||||
end
|
||||
return ""
|
||||
return pre_blank .. post_blank
|
||||
end))
|
||||
end
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue