diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2010-11-13 12:16:51 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2010-11-13 12:16:51 +0000 |
commit | 5a03beffcb753780f3442ce3899713d08aeb0562 (patch) | |
tree | 651639d8fde6298e1ff846bc08514c0bd4f97123 /libs/core/luasrc | |
parent | 8ac568acb018702b2d8234b74773877e470e4ae5 (diff) |
libs/core: switch to C pcdata() implementation, its up to 7 times faster while also ensuring safe UTF-8
Diffstat (limited to 'libs/core/luasrc')
-rw-r--r-- | libs/core/luasrc/util.lua | 22 |
1 files changed, 4 insertions, 18 deletions
diff --git a/libs/core/luasrc/util.lua b/libs/core/luasrc/util.lua index 79efa55457..7856d11629 100644 --- a/libs/core/luasrc/util.lua +++ b/libs/core/luasrc/util.lua @@ -31,6 +31,7 @@ local debug = require "debug" local ldebug = require "luci.debug" local string = require "string" local coroutine = require "coroutine" +local tparser = require "luci.template.parser" local getmetatable, setmetatable = getmetatable, setmetatable local rawget, rawset, unpack = rawget, rawset, unpack @@ -193,25 +194,8 @@ end --- Create valid XML PCDATA from given string. -- @param value String value containing the data to escape -- @return String value containing the escaped data -local function _pcdata_repl(c) - local i = string.byte(c) - - if ( i >= 0x00 and i <= 0x08 ) or ( i >= 0x0B and i <= 0x0C ) or - ( i >= 0x0E and i <= 0x1F ) or ( i == 0x7F ) - then - return "" - - elseif ( i == 0x26 ) or ( i == 0x27 ) or ( i == 0x22 ) or - ( i == 0x3C ) or ( i == 0x3E ) - then - return string.format("&#%i;", i) - end - - return c -end - function pcdata(value) - return value and tostring(value):gsub("[&\"'<>%c]", _pcdata_repl) + return value and tparser.sanitize_pcdata(tostring(value)) end --- Strip HTML tags from given string. @@ -293,6 +277,8 @@ function imatch(v) v = "" elseif type(v) == "table" then v = table.concat(v, " ") + elseif type(v) ~= "string" then + v = tostring(v) end return v:gmatch("%S+") |