| ICU 60.2
    60.2
    | 
Basic types and constants for UTF. More...
Go to the source code of this file.
| Macros | |
| #define | U_CFUNC extern | 
| This is used in a declaration of a library private ICU C function.  More... | |
| #define | U_CDECL_BEGIN | 
| This is used to begin a declaration of a library private ICU C API.  More... | |
| #define | U_CDECL_END | 
| This is used to end a declaration of a library private ICU C API.  More... | |
| #define | U_ATTRIBUTE_DEPRECATED | 
| This is used for GCC specific attributes.  More... | |
| #define | U_CAPI U_CFUNC U_EXPORT | 
| This is used to declare a function as a public ICU C API.  More... | |
| #define | U_STABLE U_CAPI | 
| This is used to declare a function as a stable public ICU C API. | |
| #define | U_DRAFT U_CAPI | 
| This is used to declare a function as a draft public ICU C API. | |
| #define | U_DEPRECATED U_CAPI U_ATTRIBUTE_DEPRECATED | 
| This is used to declare a function as a deprecated public ICU C API. | |
| #define | U_OBSOLETE U_CAPI | 
| This is used to declare a function as an obsolete public ICU C API. | |
| #define | U_INTERNAL U_CAPI | 
| This is used to declare a function as an internal ICU C API. | |
| #define | INT8_MIN ((int8_t)(-128)) | 
| The smallest value an 8 bit signed integer can hold.  More... | |
| #define | INT16_MIN ((int16_t)(-32767-1)) | 
| The smallest value a 16 bit signed integer can hold.  More... | |
| #define | INT32_MIN ((int32_t)(-2147483647-1)) | 
| The smallest value a 32 bit signed integer can hold.  More... | |
| #define | INT8_MAX ((int8_t)(127)) | 
| The largest value an 8 bit signed integer can hold.  More... | |
| #define | INT16_MAX ((int16_t)(32767)) | 
| The largest value a 16 bit signed integer can hold.  More... | |
| #define | INT32_MAX ((int32_t)(2147483647)) | 
| The largest value a 32 bit signed integer can hold.  More... | |
| #define | UINT8_MAX ((uint8_t)(255U)) | 
| The largest value an 8 bit unsigned integer can hold.  More... | |
| #define | UINT16_MAX ((uint16_t)(65535U)) | 
| The largest value a 16 bit unsigned integer can hold.  More... | |
| #define | UINT32_MAX ((uint32_t)(4294967295U)) | 
| The largest value a 32 bit unsigned integer can hold.  More... | |
| #define | INT64_C(c) c ## LL | 
| Provides a platform independent way to specify a signed 64-bit integer constant.  More... | |
| #define | UINT64_C(c) c ## ULL | 
| Provides a platform independent way to specify an unsigned 64-bit integer constant.  More... | |
| #define | U_INT64_MIN ((int64_t)(INT64_C(-9223372036854775807)-1)) | 
| The smallest value a 64 bit signed integer can hold.  More... | |
| #define | U_INT64_MAX ((int64_t)(INT64_C(9223372036854775807))) | 
| The largest value a 64 bit signed integer can hold.  More... | |
| #define | U_UINT64_MAX ((uint64_t)(UINT64_C(18446744073709551615))) | 
| The largest value a 64 bit unsigned integer can hold.  More... | |
| #define | TRUE 1 | 
| The TRUE value of a UBool.  More... | |
| #define | FALSE 0 | 
| The FALSE value of a UBool.  More... | |
| #define | U_SIZEOF_UCHAR 2 | 
| Number of bytes in a UChar.  More... | |
| #define | U_CHAR16_IS_TYPEDEF 0 | 
| If 1, then char16_t is a typedef and not a real type (yet)  More... | |
| #define | U_SENTINEL (-1) | 
| This value is intended for sentinel values for APIs that (take or) return single code points (UChar32).  More... | |
| Typedefs | |
| typedef int8_t | UBool | 
| The ICU boolean type.  More... | |
| typedef uint16_t | UChar | 
| The base type for UTF-16 code units and pointers.  More... | |
| typedef uint16_t | OldUChar | 
| Default ICU 58 definition of UChar.  More... | |
| typedef int32_t | UChar32 | 
| Define UChar32 as a type for single Unicode code points.  More... | |
Basic types and constants for UTF.
This file defines basic types and constants for utf.h to be platform-independent. umachine.h and utf.h are included into utypes.h to provide all the general definitions for ICU. All of these definitions used to be in utypes.h before the UTF-handling macros made this unmaintainable.
Definition in file umachine.h.
| #define FALSE 0 | 
The FALSE value of a UBool.
Definition at line 244 of file umachine.h.
Referenced by icu::number::impl::SymbolsWrapper::copyErrorTo(), icu::Edits::Iterator::findDestinationIndex(), icu::Edits::getCoarseIterator(), icu::Edits::getFineChangesIterator(), icu::Edits::getFineIterator(), icu::BytesTrie::hasUniqueValue(), icu::UCharsTrie::hasUniqueValue(), icu::BreakIterator::isBufferClone(), icu::IDNAInfo::isTransitionalDifferent(), icu::DecimalFormatSymbols::operator!=(), icu::ParsePosition::operator==(), icu::UnicodeString::truncate(), and icu::UnicodeString::UnicodeString().
| #define INT16_MAX ((int16_t)(32767)) | 
The largest value a 16 bit signed integer can hold.
Definition at line 178 of file umachine.h.
| #define INT16_MIN ((int16_t)(-32767-1)) | 
The smallest value a 16 bit signed integer can hold.
Definition at line 165 of file umachine.h.
| #define INT32_MAX ((int32_t)(2147483647)) | 
The largest value a 32 bit signed integer can hold.
Definition at line 182 of file umachine.h.
Referenced by icu::SimpleFormatter::applyPattern(), icu::UnicodeString::remove(), and icu::UnicodeString::toUTF8String().
| #define INT32_MIN ((int32_t)(-2147483647-1)) | 
The smallest value a 32 bit signed integer can hold.
Definition at line 169 of file umachine.h.
| #define INT64_C | ( | c | ) | c ## LL | 
Provides a platform independent way to specify a signed 64-bit integer constant.
note: may be wrong for some 64 bit platforms - ensure your compiler provides INT64_C
Definition at line 207 of file umachine.h.
| #define INT8_MAX ((int8_t)(127)) | 
The largest value an 8 bit signed integer can hold.
Definition at line 174 of file umachine.h.
| #define INT8_MIN ((int8_t)(-128)) | 
The smallest value an 8 bit signed integer can hold.
Definition at line 161 of file umachine.h.
| #define TRUE 1 | 
The TRUE value of a UBool.
Definition at line 240 of file umachine.h.
Referenced by icu::UCharsTrieBuilder::clear(), icu::number::impl::SymbolsWrapper::copyErrorTo(), icu::number::NumberFormatterSettings< UnlocalizedNumberFormatter >::copyErrorTo(), icu::Edits::Iterator::findSourceIndex(), icu::Edits::getCoarseChangesIterator(), icu::Edits::getCoarseIterator(), icu::Edits::getFineChangesIterator(), icu::UCharsTrie::Iterator::getValue(), icu::Calendar::internalSet(), icu::IDNAInfo::isTransitionalDifferent(), icu::ParsePosition::operator==(), icu::DecimalFormatSymbols::setSymbol(), icu::UnicodeString::truncate(), icu::UnicodeString::UnicodeString(), icu::ures_getNextUnicodeString(), icu::ures_getUnicodeString(), icu::ures_getUnicodeStringByIndex(), and icu::ures_getUnicodeStringByKey().
| #define U_ATTRIBUTE_DEPRECATED | 
This is used for GCC specific attributes.
This API is for internal use only.
Definition at line 104 of file umachine.h.
This is used to declare a function as a public ICU C API.
Definition at line 109 of file umachine.h.
| #define U_CDECL_BEGIN | 
This is used to begin a declaration of a library private ICU C API.
Definition at line 84 of file umachine.h.
| #define U_CDECL_END | 
This is used to end a declaration of a library private ICU C API.
Definition at line 85 of file umachine.h.
| #define U_CFUNC extern | 
This is used in a declaration of a library private ICU C function.
Definition at line 83 of file umachine.h.
| #define U_CHAR16_IS_TYPEDEF 0 | 
If 1, then char16_t is a typedef and not a real type (yet)
This API is for internal use only.
Definition at line 303 of file umachine.h.
| #define U_INT64_MAX ((int64_t)(INT64_C(9223372036854775807))) | 
The largest value a 64 bit signed integer can hold.
Definition at line 223 of file umachine.h.
| #define U_INT64_MIN ((int64_t)(INT64_C(-9223372036854775807)-1)) | 
The smallest value a 64 bit signed integer can hold.
Definition at line 219 of file umachine.h.
| #define U_SENTINEL (-1) | 
This value is intended for sentinel values for APIs that (take or) return single code points (UChar32).
It is outside of the Unicode code point range 0..0x10ffff.
For example, a "done" or "error" value in a new API could be indicated with U_SENTINEL.
ICU APIs designed before ICU 2.4 usually define service-specific "done" values, mostly 0xffff. Those may need to be distinguished from actual U+ffff text contents by calling functions like CharacterIterator::hasNext() or UnicodeString::length().
Definition at line 416 of file umachine.h.
| #define U_SIZEOF_UCHAR 2 | 
Number of bytes in a UChar.
Definition at line 291 of file umachine.h.
Referenced by icu::UnicodeString::UnicodeString().
| #define U_UINT64_MAX ((uint64_t)(UINT64_C(18446744073709551615))) | 
The largest value a 64 bit unsigned integer can hold.
Definition at line 227 of file umachine.h.
| #define UINT16_MAX ((uint16_t)(65535U)) | 
The largest value a 16 bit unsigned integer can hold.
Definition at line 191 of file umachine.h.
| #define UINT32_MAX ((uint32_t)(4294967295U)) | 
The largest value a 32 bit unsigned integer can hold.
Definition at line 195 of file umachine.h.
| #define UINT64_C | ( | c | ) | c ## ULL | 
Provides a platform independent way to specify an unsigned 64-bit integer constant.
note: may be wrong for some 64 bit platforms - ensure your compiler provides UINT64_C
Definition at line 215 of file umachine.h.
| #define UINT8_MAX ((uint8_t)(255U)) | 
The largest value an 8 bit unsigned integer can hold.
Definition at line 187 of file umachine.h.
Default ICU 58 definition of UChar.
A base type for UTF-16 code units and pointers. Unsigned 16-bit integer.
Define OldUChar to be wchar_t if that is 16 bits wide. If wchar_t is not 16 bits wide, then define UChar to be uint16_t.
This makes the definition of OldUChar platform-dependent but allows direct string type compatibility with platforms with 16-bit wchar_t types.
This is how UChar was defined in ICU 58, for transition convenience. Exception: ICU 58 UChar was defined to UCHAR_TYPE if that macro was defined. The current UChar responds to UCHAR_TYPE but OldUChar does not.
Definition at line 376 of file umachine.h.
| typedef int8_t UBool | 
The base type for UTF-16 code units and pointers.
Unsigned 16-bit integer. Starting with ICU 59, C++ API uses char16_t directly, while C API continues to use UChar.
UChar is configurable by defining the macro UCHAR_TYPE on the preprocessor or compiler command line: -DUCHAR_TYPE=uint16_t or -DUCHAR_TYPE=wchar_t (if U_SIZEOF_WCHAR_T==2) etc. (The UCHAR_TYPE can also be #defined earlier in this file, for outside the ICU library code.) This is for transitional use from application code that uses uint16_t or wchar_t for UTF-16.
The default is UChar=char16_t.
C++11 defines char16_t as bit-compatible with uint16_t, but as a distinct type.
In C, char16_t is a simple typedef of uint_least16_t. ICU requires uint_least16_t=uint16_t for data memory mapping. On macOS, char16_t is not available because the uchar.h standard header is missing.
Definition at line 349 of file umachine.h.
| typedef int32_t UChar32 | 
Define UChar32 as a type for single Unicode code points.
UChar32 is a signed 32-bit integer (same as int32_t).
The Unicode code point range is 0..0x10ffff. All other values (negative or >=0x110000) are illegal as Unicode code points. They may be used as sentinel values to indicate "done", "error" or similar non-code point conditions.
Before ICU 2.4 (Jitterbug 2146), UChar32 was defined to be wchar_t if that is 32 bits wide (wchar_t may be signed or unsigned) or else to be uint32_t. That is, the definition of UChar32 was platform-dependent.
Definition at line 396 of file umachine.h.
 1.8.11
 1.8.11