mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-10-13 10:07:38 -04:00
unicode: Support characters beyond the first unicode plane
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 * font manipulation, caching, rendering, and generation * on-screen keyboard * FAT filesystem (parsing and generating utf16 LFNs) * WIN32 simulator platform code Note that this patch doesn't _enable_ >16bit unicode support; a followup patch will turn that on for appropriate targets. Appears to work on: * hosted linux, native, linux simulator in both 16/32-bit modes. Needs testing on: * windows and macos simulator (16bit+32bit) Change-Id: Iba111b27d2433019b6bff937cf1ebd2c4353a0e8
This commit is contained in:
parent
2a88253426
commit
a2c10f6189
44 changed files with 476 additions and 330 deletions
|
@ -225,7 +225,7 @@ void beep_play(unsigned int frequency, unsigned int duration, unsigned int ampli
|
|||
\param amplitude
|
||||
\description
|
||||
|
||||
unsigned short *bidi_l2v( const unsigned char *str, int orientation )
|
||||
ucschar_t *bidi_l2v( const unsigned char *str, int orientation )
|
||||
\param str
|
||||
\param orientation
|
||||
\return
|
||||
|
@ -407,13 +407,13 @@ const struct cbmp_bitmap_info_entry *core_bitmaps
|
|||
\return
|
||||
\description
|
||||
|
||||
const unsigned char *font_get_bits( struct font *pf, unsigned short char_code )
|
||||
const unsigned char *font_get_bits( struct font *pf, ucschar_t char_code )
|
||||
\param pf
|
||||
\param char_code
|
||||
\return
|
||||
\description
|
||||
|
||||
const unsigned char* utf8decode(const unsigned char *utf8, unsigned short *ucs)
|
||||
const unsigned char* utf8decode(const unsigned char *utf8, ucschar_t *ucs)
|
||||
\group unicode stuff
|
||||
\param utf8
|
||||
\param ucs
|
||||
|
@ -747,7 +747,7 @@ int font_getstringsize(const unsigned char *str, int *w, int *h, int fontnumber)
|
|||
\return
|
||||
\description
|
||||
|
||||
int font_get_width(struct font* pf, unsigned short char_code)
|
||||
int font_get_width(struct font* pf, ucschar_t char_code)
|
||||
\param pf
|
||||
\param char_code
|
||||
\return
|
||||
|
@ -972,7 +972,7 @@ bool is_diacritic(const unsigned short char_code, bool *is_rtl)
|
|||
\return
|
||||
\description
|
||||
|
||||
int kbd_input(char* buffer, int buflen, unsigned short *kbd)
|
||||
int kbd_input(char* buffer, int buflen, ucschar_t *kbd)
|
||||
\group misc
|
||||
\param buffer
|
||||
\param buflen
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue