ICU 65.1
65.1
|
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 | U_OVERRIDE override |
Defined to the C++11 "override" keyword if available. More... | |
#define | U_FINAL final |
Defined to the C++11 "final" keyword if available. More... | |
#define | UPRV_BLOCK_MACRO_BEGIN do |
Defined as the "do" keyword by default. More... | |
#define | UPRV_BLOCK_MACRO_END while (FALSE) |
Defined as "while (FALSE)" by default. More... | |
#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 269 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 203 of file umachine.h.
#define INT16_MIN ((int16_t)(-32767-1)) |
The smallest value a 16 bit signed integer can hold.
Definition at line 190 of file umachine.h.
#define INT32_MAX ((int32_t)(2147483647)) |
The largest value a 32 bit signed integer can hold.
Definition at line 207 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 194 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 232 of file umachine.h.
#define INT8_MAX ((int8_t)(127)) |
The largest value an 8 bit signed integer can hold.
Definition at line 199 of file umachine.h.
#define INT8_MIN ((int8_t)(-128)) |
The smallest value an 8 bit signed integer can hold.
Definition at line 186 of file umachine.h.
#define TRUE 1 |
The TRUE value of a UBool.
Definition at line 265 of file umachine.h.
Referenced by icu::UCharsTrieBuilder::clear(), icu::number::NumberRangeFormatterSettings< LocalizedNumberRangeFormatter >::copyErrorTo(), 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 332 of file umachine.h.
#define U_FINAL final |
Defined to the C++11 "final" keyword if available.
Denotes a class or member which may not be overridden in subclasses. May result in an error if subclasses attempt to override.
Definition at line 140 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 248 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 244 of file umachine.h.
#define U_OVERRIDE override |
Defined to the C++11 "override" keyword if available.
Denotes a class or member which is an override of the base class. May result in an error if it applied to something not an override.
Definition at line 129 of file umachine.h.
Referenced by icu::FilteredNormalizer2::FilteredNormalizer2(), icu::FormattedDateInterval::FormattedDateInterval(), icu::FormattedList::FormattedList(), icu::number::FormattedNumber::FormattedNumber(), and icu::FormattedRelativeDateTime::FormattedRelativeDateTime().
#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 445 of file umachine.h.
#define U_SIZEOF_UCHAR 2 |
Number of bytes in a UChar.
Definition at line 316 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 252 of file umachine.h.
#define UINT16_MAX ((uint16_t)(65535U)) |
The largest value a 16 bit unsigned integer can hold.
Definition at line 216 of file umachine.h.
#define UINT32_MAX ((uint32_t)(4294967295U)) |
The largest value a 32 bit unsigned integer can hold.
Definition at line 220 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 240 of file umachine.h.
Referenced by icu::BytesTrie::Iterator::getValue(), and icu::UCharsTrie::Iterator::getValue().
#define UINT8_MAX ((uint8_t)(255U)) |
The largest value an 8 bit unsigned integer can hold.
Definition at line 212 of file umachine.h.
#define UPRV_BLOCK_MACRO_BEGIN do |
Defined as the "do" keyword by default.
Definition at line 168 of file umachine.h.
#define UPRV_BLOCK_MACRO_END while (FALSE) |
Defined as "while (FALSE)" by default.
Definition at line 177 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 405 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 378 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 425 of file umachine.h.