mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-10-13 18:17:39 -04:00
internals: Support characters beyond the first unicode plane (WIP)
We used 16-bit variables to store the 'character code' everywhere but this won't let us represent anything beyond U+FFFF. This patch changes those variables to a custom type that can be 32 or 16 bits depending on the build, and adjusts numerous internal APIs and datastructures to match. This includes: * utf8decode() and friends * on-screen keyboard * font manipulation, caching, rendering, and generation * VFAT code parses and generates utf16 dirents * WIN32 simulator reads and writes utf16 filenames Note that this patch doesn't _enable_ >16bit unicode support; a followup patch will turn that on for appropriate targets. Known bugs: * Native players in 32-bit unicode mode generate mangled filename entries if they include UTF16 surrogate codepoints. Root cause is unclear, and may reside in core dircache code. Needs testing on: * windows simulator (16bit+32bit) Change-Id: I193a00fe2a11a4181ddc82df2d71be52bf00b6e6
This commit is contained in:
parent
94712b34d4
commit
d05c59f35b
44 changed files with 480 additions and 335 deletions
|
@ -128,7 +128,7 @@ void wait_for_key()
|
|||
case PLA_EXIT:
|
||||
hot_key_quit();
|
||||
break;
|
||||
|
||||
|
||||
case PLA_SELECT:
|
||||
return;
|
||||
}
|
||||
|
@ -159,7 +159,7 @@ zchar do_input(int timeout, bool show_cursor)
|
|||
{
|
||||
case PLA_EXIT:
|
||||
return ZC_HKEY_QUIT;
|
||||
|
||||
|
||||
case PLA_CANCEL:
|
||||
menu_ret = menu();
|
||||
if (menu_ret != ZC_BAD)
|
||||
|
@ -174,7 +174,7 @@ zchar do_input(int timeout, bool show_cursor)
|
|||
return ZC_BAD;
|
||||
|
||||
default:
|
||||
if (timeout != TIMEOUT_BLOCK &&
|
||||
if (timeout != TIMEOUT_BLOCK &&
|
||||
!TIME_BEFORE(*rb->current_tick, timeout_at))
|
||||
return ZC_TIME_OUT;
|
||||
}
|
||||
|
@ -185,7 +185,7 @@ zchar os_read_key(int timeout, bool show_cursor)
|
|||
{
|
||||
int r;
|
||||
char inputbuf[5];
|
||||
short key;
|
||||
ucschar_t key;
|
||||
zchar zkey;
|
||||
|
||||
for(;;)
|
||||
|
@ -214,7 +214,7 @@ zchar os_read_line(int max, zchar *buf, int timeout, int width, int continued)
|
|||
char inputbuf[256];
|
||||
const char *in;
|
||||
char *out;
|
||||
short key;
|
||||
ucschar_t key;
|
||||
zchar zkey;
|
||||
|
||||
for(;;)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue