mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.json: Unescape surrogate pairs
This commit is contained in:
parent
479ea4dd26
commit
14b0dd8bdf
1 changed files with 5 additions and 4 deletions
|
@ -246,7 +246,7 @@ local function _readarray(json, index)
|
|||
end
|
||||
end
|
||||
local _unescape_error;
|
||||
local function _unescape_surrogate_func(x) -- luacheck: ignore
|
||||
local function _unescape_surrogate_func(x)
|
||||
local lead, trail = tonumber(x:sub(3, 6), 16), tonumber(x:sub(9, 12), 16);
|
||||
local codepoint = lead * 0x400 + trail - 0x35FDC00;
|
||||
local a = codepoint % 64;
|
||||
|
@ -260,8 +260,9 @@ end
|
|||
local function _unescape_func(x)
|
||||
x = x:match("%x%x%x%x", 3);
|
||||
if x then
|
||||
--if x >= 0xD800 and x <= 0xDFFF then _unescape_error = true; end -- bad surrogate pair
|
||||
return codepoint_to_utf8(tonumber(x, 16));
|
||||
local codepoint = tonumber(x, 16)
|
||||
if codepoint >= 0xD800 and codepoint <= 0xDFFF then _unescape_error = true; end -- bad surrogate pair
|
||||
return codepoint_to_utf8(codepoint);
|
||||
end
|
||||
_unescape_error = true;
|
||||
end
|
||||
|
@ -273,7 +274,7 @@ function _readstring(json, index)
|
|||
--if s:find("[%z-\31]") then return nil, "control char in string"; end
|
||||
-- FIXME handle control characters
|
||||
_unescape_error = nil;
|
||||
--s = s:gsub("\\u[dD][89abAB]%x%x\\u[dD][cdefCDEF]%x%x", _unescape_surrogate_func);
|
||||
s = s:gsub("\\u[dD][89abAB]%x%x\\u[dD][cdefCDEF]%x%x", _unescape_surrogate_func);
|
||||
-- FIXME handle escapes beyond BMP
|
||||
s = s:gsub("\\u.?.?.?.?", _unescape_func);
|
||||
if _unescape_error then return nil, "invalid escape"; end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue