-
Notifications
You must be signed in to change notification settings - Fork 433
API Unicode
For those that don't like images: the wiki has moved to a new place, http://ocdoc.cil.li/.
This wiki will no longer be updated.
Because all strings pass through Java at some point it can be useful to handle them with Unicode support (since Java's internal string representation is UTF-8 encoded). In particular, screens display UTF-8 strings, meaning the related GPU functions expect UTF-8 strings. Also, keyboard input will generally be UTF-8 encoded, especially the clipboard.
However, keep in mind that only a subset of UTF-8 can actually be displayed on screens. Specifically all glyphs defined in code page 437 are supported.
The following functions are provided to allow basic UTF-8 handling:
-
unicode.char(value: number, ...): string
UTF-8 aware version ofstring.char
. The values may be in the full UTF-8 range, not just ASCII. -
unicode.len(value: string): number
UTF-8 aware version ofstring.len
. For example, forÜmläüt
it'll return6
, wherestring.len
would return9
. -
unicode.lower(value: string): string
UTF-8 aware version ofstring.lower
. -
unicode.reverse(value: string): string
UTF-8 aware version ofstring.reverse
. For example, forÜmläüt
it'll returntüälmÜ
, wherestring.reverse
would returntälm
. -
unicode.sub(value: string, i:number[, j:number]): string
UTF-8 aware version ofstring.sub
. -
unicode.upper(value: string): string
UTF-8 aware version ofstring.upper
.
For example, these are used when files are opened in non-binary mode. The original string functions are used for files opened in binary mode.