blob: d51b4cfb7634f50828c08eb2e7bb73b32764d17b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
local function tochar(code)
return string.char(code & 0xFF, (code >> 8) & 0xFF)
end
local function tobyte(s, i)
local l, h = string.byte(s, i, i+1)
return (h << 8) | l
end
local function char(code)
if code <= 0xFFFF then
return tochar(code)
end
code = code - 0x10000
return tochar(0xD800 + (code >> 10))..tochar(0xDC00 + (code & 0x3FF))
end
local m = {}
function m.encode(s)
local r = {}
for _, c in utf8.codes(s, true) do
r[#r+1] = char(c)
end
return table.concat(r)
end
function m.decode(s)
local r = {}
local i = 1
while i < #s do
local code1 = tobyte(s, i)
if code1 >= 0xD800 and code1 < 0xE000 then
i = i + 2
local code2 = tobyte(s, i)
local code = 0x10000 + ((code1 - 0xD800) << 10) + ((code2 - 0xDC00) & 0x3FF)
r[#r+1] = utf8.char(code)
else
r[#r+1] = utf8.char(code1)
end
i = i + 2
end
return table.concat(r)
end
return m
|