std.utf
Encode and decode UTF-8, UTF-16 and UTF-32 strings.For Win32 systems, the C wchar_t type is UTF-16 and corresponds to the D wchar type. For linux systems, the C wchar_t type is UTF-32 and corresponds to the D utf.dchar type.
UTF character support is restricted to (\u0000 <= character <= \U0010FFFF).
See Also:
Wikipedia
http://www.cl.cam.ac.uk/~mgk25/unicode.html#utf-8
http://anubis.dkuug.dk/JTC1/SC2/WG2/docs/n1335
- Exception class that is thrown upon any errors.
- index in string of where error occurred
- Test if c is a valid UTF-32 character.
\uFFFE and \uFFFF are considered valid by this function, as they are permitted for internal use by an application, but they are not allowed for interchange by the Unicode standard.
Returns:
true if it is, false if not.
- stride() returns the length of a UTF-8 sequence starting at index i
in string s.
Returns:
The number of bytes in the UTF-8 sequence or 0xFF meaning s[i] is not the start of of UTF-8 sequence.
- stride() returns the length of a UTF-16 sequence starting at index i
in string s.
- stride() returns the length of a UTF-32 sequence starting at index i
in string s.
Returns:
The return value will always be 1.
- Given an index i into an array of characters s[],
and assuming that index i is at the start of a UTF character,
determine the number of UCS characters up to that index i.
- Given a UCS index n into an array of characters s[], return the UTF index.
- Decodes and returns character starting at s[idx]. idx is advanced past the
decoded character. If the character is not well formed, a UtfException is
thrown and idx remains unchanged.
- Encodes character c and appends it to array s[].
- Returns the code length of c in the encoding using C as a
code point. The code is returned in character count, not in bytes.
- Checks to see if string is well formed or not. S can be an array
of char, wchar, or dchar. Throws a UtfException
if it is not. Use to check all untrusted input for correctness.
- Encodes string s into UTF-8 and returns the encoded string.
- Encodes string s into UTF-16 and returns the encoded string.
toUTF16z() is suitable for calling the 'W' functions in the Win32 API that take
an LPWSTR or LPCWSTR argument.
- Encodes string s into UTF-32 and returns the encoded string.