Rizin
unix-like reverse engineering framework and cli tools
|
C API: 16-bit Unicode handling macros. More...
Go to the source code of this file.
Macros | |
#define | U16_IS_SINGLE(c) !U_IS_SURROGATE(c) |
#define | U16_IS_LEAD(c) (((c)&0xfffffc00)==0xd800) |
#define | U16_IS_TRAIL(c) (((c)&0xfffffc00)==0xdc00) |
#define | U16_IS_SURROGATE(c) U_IS_SURROGATE(c) |
#define | U16_IS_SURROGATE_LEAD(c) (((c)&0x400)==0) |
#define | U16_IS_SURROGATE_TRAIL(c) (((c)&0x400)!=0) |
#define | U16_SURROGATE_OFFSET ((0xd800<<10UL)+0xdc00-0x10000) |
#define | U16_GET_SUPPLEMENTARY(lead, trail) (((UChar32)(lead)<<10UL)+(UChar32)(trail)-U16_SURROGATE_OFFSET) |
#define | U16_LEAD(supplementary) (UChar)(((supplementary)>>10)+0xd7c0) |
#define | U16_TRAIL(supplementary) (UChar)(((supplementary)&0x3ff)|0xdc00) |
#define | U16_LENGTH(c) ((uint32_t)(c)<=0xffff ? 1 : 2) |
#define | U16_MAX_LENGTH 2 |
#define | U16_GET_UNSAFE(s, i, c) |
#define | U16_GET(s, start, i, length, c) |
#define | U16_GET_OR_FFFD(s, start, i, length, c) |
#define | U16_NEXT_UNSAFE(s, i, c) |
#define | U16_NEXT(s, i, length, c) |
#define | U16_NEXT_OR_FFFD(s, i, length, c) |
#define | U16_APPEND_UNSAFE(s, i, c) |
#define | U16_APPEND(s, i, capacity, c, isError) |
#define | U16_FWD_1_UNSAFE(s, i) |
#define | U16_FWD_1(s, i, length) |
#define | U16_FWD_N_UNSAFE(s, i, n) |
#define | U16_FWD_N(s, i, length, n) |
#define | U16_SET_CP_START_UNSAFE(s, i) |
#define | U16_SET_CP_START(s, start, i) |
#define | U16_PREV_UNSAFE(s, i, c) |
#define | U16_PREV(s, start, i, c) |
#define | U16_PREV_OR_FFFD(s, start, i, c) |
#define | U16_BACK_1_UNSAFE(s, i) |
#define | U16_BACK_1(s, start, i) |
#define | U16_BACK_N_UNSAFE(s, i, n) |
#define | U16_BACK_N(s, start, i, n) |
#define | U16_SET_CP_LIMIT_UNSAFE(s, i) |
#define | U16_SET_CP_LIMIT(s, start, i, length) |
C API: 16-bit Unicode handling macros.
This file defines macros to deal with 16-bit Unicode (UTF-16) code units and strings.
For more information see utf.h and the ICU User Guide Strings chapter (http://userguide.icu-project.org/strings).
Usage: ICU coding guidelines for if() statements should be followed when using these macros. Compound statements (curly braces {}) must be used for if-else-while... bodies and all macro statements should be terminated with semicolon.
Definition in file utf16.h.
Append a code point to a string, overwriting 1 or 2 code units. The offset points to the current end of the string contents and is advanced (post-increment). "Safe" macro, checks for a valid code point. If a surrogate pair is written, checks for sufficient space in the string. If the code point is not valid or a trail surrogate does not fit, then isError is set to TRUE.
s | const UChar * string buffer |
i | string offset, must be i<capacity |
capacity | size of the string buffer |
c | code point to append |
isError | output UBool set to TRUE if an error occurs, otherwise not modified |
Append a code point to a string, overwriting 1 or 2 code units. The offset points to the current end of the string contents and is advanced (post-increment). "Unsafe" macro, assumes a valid code point and sufficient space in the string. Otherwise, the result is undefined.
s | const UChar * string buffer |
i | string offset |
c | code point to append |
Move the string offset from one code point boundary to the previous one. (Pre-decrementing backward iteration.) The input offset may be the same as the string length. "Safe" macro, handles unpaired surrogates and checks for string boundaries.
s | const UChar * string |
start | starting string offset (usually 0) |
i | string offset, must be start<i |
Move the string offset from one code point boundary to the previous one. (Pre-decrementing backward iteration.) The input offset may be the same as the string length. "Unsafe" macro, assumes well-formed UTF-16.
s | const UChar * string |
i | string offset |
Move the string offset from one code point boundary to the n-th one before it, i.e., move backward by n code points. (Pre-decrementing backward iteration.) The input offset may be the same as the string length. "Safe" macro, handles unpaired surrogates and checks for string boundaries.
s | const UChar * string |
start | start of string |
i | string offset, must be start<i |
n | number of code points to skip |
Move the string offset from one code point boundary to the n-th one before it, i.e., move backward by n code points. (Pre-decrementing backward iteration.) The input offset may be the same as the string length. "Unsafe" macro, assumes well-formed UTF-16.
s | const UChar * string |
i | string offset |
n | number of code points to skip |
Advance the string offset from one code point boundary to the next. (Post-incrementing iteration.) "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The length can be negative for a NUL-terminated string.
s | const UChar * string |
i | string offset, must be i<length |
length | string length |
Advance the string offset from one code point boundary to the next. (Post-incrementing iteration.) "Unsafe" macro, assumes well-formed UTF-16.
s | const UChar * string |
i | string offset |
Advance the string offset from one code point boundary to the n-th next one, i.e., move forward by n code points. (Post-incrementing iteration.) "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The length can be negative for a NUL-terminated string.
s | const UChar * string |
i | int32_t string offset, must be i<length |
length | int32_t string length |
n | number of code points to skip |
Advance the string offset from one code point boundary to the n-th next one, i.e., move forward by n code points. (Post-incrementing iteration.) "Unsafe" macro, assumes well-formed UTF-16.
s | const UChar * string |
i | string offset |
n | number of code points to skip |
Get a code point from a string at a random-access offset, without changing the offset. "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The offset may point to either the lead or trail surrogate unit for a supplementary code point, in which case the macro will read the adjacent matching surrogate as well.
The length can be negative for a NUL-terminated string.
If the offset points to a single, unpaired surrogate, then c is set to that unpaired surrogate. Iteration through a string is more efficient with U16_NEXT_UNSAFE or U16_NEXT.
s | const UChar * string |
start | starting string offset (usually 0) |
i | string offset, must be start<=i<length |
length | string length |
c | output UChar32 variable |
Get a code point from a string at a random-access offset, without changing the offset. "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The offset may point to either the lead or trail surrogate unit for a supplementary code point, in which case the macro will read the adjacent matching surrogate as well.
The length can be negative for a NUL-terminated string.
If the offset points to a single, unpaired surrogate, then c is set to U+FFFD. Iteration through a string is more efficient with U16_NEXT_UNSAFE or U16_NEXT_OR_FFFD.
s | const UChar * string |
start | starting string offset (usually 0) |
i | string offset, must be start<=i<length |
length | string length |
c | output UChar32 variable |
#define U16_GET_SUPPLEMENTARY | ( | lead, | |
trail | |||
) | (((UChar32)(lead)<<10UL)+(UChar32)(trail)-U16_SURROGATE_OFFSET) |
Get a supplementary code point value (U+10000..U+10ffff) from its lead and trail surrogates. The result is undefined if the input values are not lead and trail surrogates.
lead | lead surrogate (U+d800..U+dbff) |
trail | trail surrogate (U+dc00..U+dfff) |
Get a code point from a string at a random-access offset, without changing the offset. "Unsafe" macro, assumes well-formed UTF-16.
The offset may point to either the lead or trail surrogate unit for a supplementary code point, in which case the macro will read the adjacent matching surrogate as well. The result is undefined if the offset points to a single, unpaired surrogate. Iteration through a string is more efficient with U16_NEXT_UNSAFE or U16_NEXT.
s | const UChar * string |
i | string offset |
c | output UChar32 variable |
Assuming c is a surrogate code point (U16_IS_SURROGATE(c)), is it a lead surrogate?
c | 16-bit code unit |
Assuming c is a surrogate code point (U16_IS_SURROGATE(c)), is it a trail surrogate?
c | 16-bit code unit |
#define U16_LEAD | ( | supplementary | ) | (UChar)(((supplementary)>>10)+0xd7c0) |
#define U16_MAX_LENGTH 2 |
Get a code point from a string at a code point boundary offset, and advance the offset to the next code point boundary. (Post-incrementing forward iteration.) "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The length can be negative for a NUL-terminated string.
The offset may point to the lead surrogate unit for a supplementary code point, in which case the macro will read the following trail surrogate as well. If the offset points to a trail surrogate or to a single, unpaired lead surrogate, then c is set to that unpaired surrogate.
s | const UChar * string |
i | string offset, must be i<length |
length | string length |
c | output UChar32 variable |
Get a code point from a string at a code point boundary offset, and advance the offset to the next code point boundary. (Post-incrementing forward iteration.) "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The length can be negative for a NUL-terminated string.
The offset may point to the lead surrogate unit for a supplementary code point, in which case the macro will read the following trail surrogate as well. If the offset points to a trail surrogate or to a single, unpaired lead surrogate, then c is set to U+FFFD.
s | const UChar * string |
i | string offset, must be i<length |
length | string length |
c | output UChar32 variable |
Get a code point from a string at a code point boundary offset, and advance the offset to the next code point boundary. (Post-incrementing forward iteration.) "Unsafe" macro, assumes well-formed UTF-16.
The offset may point to the lead surrogate unit for a supplementary code point, in which case the macro will read the following trail surrogate as well. If the offset points to a trail surrogate, then that itself will be returned as the code point. The result is undefined if the offset points to a single, unpaired lead surrogate.
s | const UChar * string |
i | string offset |
c | output UChar32 variable |
Move the string offset from one code point boundary to the previous one and get the code point between them. (Pre-decrementing backward iteration.) "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The input offset may be the same as the string length. If the offset is behind a trail surrogate unit for a supplementary code point, then the macro will read the preceding lead surrogate as well. If the offset is behind a lead surrogate or behind a single, unpaired trail surrogate, then c is set to that unpaired surrogate.
s | const UChar * string |
start | starting string offset (usually 0) |
i | string offset, must be start<i |
c | output UChar32 variable |
Move the string offset from one code point boundary to the previous one and get the code point between them. (Pre-decrementing backward iteration.) "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The input offset may be the same as the string length. If the offset is behind a trail surrogate unit for a supplementary code point, then the macro will read the preceding lead surrogate as well. If the offset is behind a lead surrogate or behind a single, unpaired trail surrogate, then c is set to U+FFFD.
s | const UChar * string |
start | starting string offset (usually 0) |
i | string offset, must be start<i |
c | output UChar32 variable |
Move the string offset from one code point boundary to the previous one and get the code point between them. (Pre-decrementing backward iteration.) "Unsafe" macro, assumes well-formed UTF-16.
The input offset may be the same as the string length. If the offset is behind a trail surrogate unit for a supplementary code point, then the macro will read the preceding lead surrogate as well. If the offset is behind a lead surrogate, then that itself will be returned as the code point. The result is undefined if the offset is behind a single, unpaired trail surrogate.
s | const UChar * string |
i | string offset |
c | output UChar32 variable |
Adjust a random-access offset to a code point boundary after a code point. If the offset is behind the lead surrogate of a surrogate pair, then the offset is incremented. Otherwise, it is not modified. The input offset may be the same as the string length. "Safe" macro, handles unpaired surrogates and checks for string boundaries.
The length can be negative for a NUL-terminated string.
s | const UChar * string |
start | int32_t starting string offset (usually 0) |
i | int32_t string offset, start<=i<=length |
length | int32_t string length |
Adjust a random-access offset to a code point boundary after a code point. If the offset is behind the lead surrogate of a surrogate pair, then the offset is incremented. Otherwise, it is not modified. The input offset may be the same as the string length. "Unsafe" macro, assumes well-formed UTF-16.
s | const UChar * string |
i | string offset |
Adjust a random-access offset to a code point boundary at the start of a code point. If the offset points to the trail surrogate of a surrogate pair, then the offset is decremented. Otherwise, it is not modified. "Safe" macro, handles unpaired surrogates and checks for string boundaries.
s | const UChar * string |
start | starting string offset (usually 0) |
i | string offset, must be start<=i |
Adjust a random-access offset to a code point boundary at the start of a code point. If the offset points to the trail surrogate of a surrogate pair, then the offset is decremented. Otherwise, it is not modified. "Unsafe" macro, assumes well-formed UTF-16.
s | const UChar * string |
i | string offset |
#define U16_SURROGATE_OFFSET ((0xd800<<10UL)+0xdc00-0x10000) |
#define U16_TRAIL | ( | supplementary | ) | (UChar)(((supplementary)&0x3ff)|0xdc00) |