mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-10-14 02:27:39 -04:00
lua fix yellow and add temploader
temp loader allows some lua requires to be loaded and later garbage collected unfortunately the module needs to be formatted in such a way to pass back a call table in order to keep the functions within from being garbage collected too early BE AWARE this bypasses the module loader which would allow code reuse so if you aren't careful this memory saving tool could spell disaster for free RAM if you load the same code multiple times Change-Id: I0b6f81e481b8c779edbd620c8403794f8353926f
This commit is contained in:
parent
489a5f3ff7
commit
9b2f23319c
4 changed files with 104 additions and 60 deletions
|
@ -1,74 +1,82 @@
|
|||
--create keyboard layout
|
||||
--BILGUS 4/2021
|
||||
local function encode_short(n)
|
||||
return string.char(bit.band(0x00FF, n), bit.rshift(bit.band(0xFF00, n), 8))
|
||||
end
|
||||
-- kbdlayout = require("create_kbd_layout")
|
||||
-- local layout = kbdlayout.create_keyboard_layout("abcd")
|
||||
local _kbdlayout = {} do
|
||||
|
||||
function utf8decode(str)
|
||||
local INVALID = 0xfffd
|
||||
local t = {}
|
||||
local function check_char(c)
|
||||
local tail = false
|
||||
local code
|
||||
c = string.byte(c)
|
||||
if (c <= 0x7f) or (c >= 0xc2) then
|
||||
-- Start of new character
|
||||
if (c < 0x80) then -- U-00000000 - U-0000007F, 1 string.byte
|
||||
code = c;
|
||||
elseif (c < 0xe0) then -- U-00000080 - U-000007FF, 2 string.bytes
|
||||
tail = 1;
|
||||
code = bit.band(c, 0x1f)
|
||||
elseif (c < 0xf0) then -- U-00000800 - U-0000FFFF, 3 string.bytes
|
||||
tail = 2;
|
||||
code = bit.band(c, 0x0f)
|
||||
elseif (c < 0xf5) then -- U-00010000 - U-001FFFFF, 4 string.bytes
|
||||
tail = 3;
|
||||
code = bit.band(c, 0x07)
|
||||
else
|
||||
-- Invalid size
|
||||
code = 0xfffd;
|
||||
end
|
||||
local function encode_short(n)
|
||||
return string.char(bit.band(0x00FF, n), bit.rshift(bit.band(0xFF00, n), 8))
|
||||
end
|
||||
|
||||
while tail and c ~= 0 do
|
||||
tail = tail - 1
|
||||
if bit.band(c, 0xc0) == 0x80 then
|
||||
-- Valid continuation character
|
||||
code = bit.bor(bit.lshift(code, 6),bit.band(c, 0x3f))
|
||||
local function utf8decode(str)
|
||||
local INVALID = 0xfffd
|
||||
local t = {}
|
||||
local function check_char(c)
|
||||
local tail = false
|
||||
local code
|
||||
c = string.byte(c)
|
||||
if (c <= 0x7f) or (c >= 0xc2) then
|
||||
-- Start of new character
|
||||
if (c < 0x80) then -- U-00000000 - U-0000007F, 1 string.byte
|
||||
code = c;
|
||||
elseif (c < 0xe0) then -- U-00000080 - U-000007FF, 2 string.bytes
|
||||
tail = 1;
|
||||
code = bit.band(c, 0x1f)
|
||||
elseif (c < 0xf0) then -- U-00000800 - U-0000FFFF, 3 string.bytes
|
||||
tail = 2;
|
||||
code = bit.band(c, 0x0f)
|
||||
elseif (c < 0xf5) then -- U-00010000 - U-001FFFFF, 4 string.bytes
|
||||
tail = 3;
|
||||
code = bit.band(c, 0x07)
|
||||
else
|
||||
-- Invalid continuation char
|
||||
code = INVALID;
|
||||
break;
|
||||
-- Invalid size
|
||||
code = 0xfffd;
|
||||
end
|
||||
|
||||
while tail and c ~= 0 do
|
||||
tail = tail - 1
|
||||
if bit.band(c, 0xc0) == 0x80 then
|
||||
-- Valid continuation character
|
||||
code = bit.bor(bit.lshift(code, 6),bit.band(c, 0x3f))
|
||||
else
|
||||
-- Invalid continuation char
|
||||
code = INVALID;
|
||||
break;
|
||||
end
|
||||
end
|
||||
else
|
||||
-- Invalid UTF-8 char
|
||||
code = INVALID;
|
||||
end
|
||||
else
|
||||
-- Invalid UTF-8 char
|
||||
code = INVALID;
|
||||
-- currently we don't support chars above U-FFFF
|
||||
t[#t + 1 ] = encode_short((code < 0x10000) and code or 0xfffd)
|
||||
end
|
||||
-- currently we don't support chars above U-FFFF
|
||||
t[#t + 1 ] = encode_short((code < 0x10000) and code or 0xfffd)
|
||||
str:gsub(".", check_char) -- run check function for every char
|
||||
return table.concat(t)
|
||||
end
|
||||
str:gsub(".", check_char) -- run check function for every char
|
||||
return table.concat(t)
|
||||
|
||||
local function create_keyboard_layout(s_layout)
|
||||
local insert = table.insert
|
||||
lines = {}
|
||||
|
||||
local t={}
|
||||
for str in string.gmatch(s_layout, "([^\n]+)") do
|
||||
local len = string.len(str)
|
||||
lines[#lines + 1] =
|
||||
table.concat({encode_short(len), utf8decode(str)})
|
||||
end
|
||||
lines[#lines + 1] = encode_short(0xFEFF)
|
||||
|
||||
return table.concat(lines)
|
||||
end
|
||||
_kbdlayout.create_keyboard_layout = create_keyboard_layout
|
||||
_kbdlayout.utf8decode = utf8decode
|
||||
end
|
||||
|
||||
function create_keyboard_layout(s_layout)
|
||||
local insert = table.insert
|
||||
lines = {}
|
||||
|
||||
local t={}
|
||||
for str in string.gmatch(s_layout, "([^\n]+)") do
|
||||
local len = string.len(str)
|
||||
lines[#lines + 1] =
|
||||
table.concat({encode_short(len), utf8decode(str)})
|
||||
end
|
||||
lines[#lines + 1] = encode_short(0xFEFF)
|
||||
|
||||
return table.concat(lines)
|
||||
end
|
||||
|
||||
--[[
|
||||
local name = "Test_KBD_LAYOUT_" .. tostring(1)
|
||||
local test = create_keyboard_layout("ABCDEFGHIJKLM\nNOPQRSTUVWXYZ\n0123456789")
|
||||
local test = _kbdlayout.create_keyboard_layout("ABCDEFGHIJKLM\nNOPQRSTUVWXYZ\n0123456789")
|
||||
local file = io.open('/' .. name, "w+") -- overwrite, rb ignores the 'b' flag
|
||||
file:write(test)-- write the layout to the file now
|
||||
file:close()
|
||||
|
@ -79,3 +87,4 @@ if not file then
|
|||
end
|
||||
rb.kbd_input(name, test)
|
||||
]]
|
||||
return _kbdlayout
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue