1b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*
2b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru******************************************************************************
3b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*
4c14898b482f76ecab9026615e2e4c6fe78358bdcFredrik Roubert*   Copyright (C) 1999-2015, International Business Machines
5b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   Corporation and others.  All Rights Reserved.
6b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*
7b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru******************************************************************************
8b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   file name:  umachine.h
9b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   encoding:   US-ASCII
10b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   tab size:   8 (not used)
11b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   indentation:4
12b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*
13b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   created on: 1999sep13
14b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   created by: Markus W. Scherer
15b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*
16f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius*   This file defines basic types and constants for ICU to be
17b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   platform-independent. umachine.h and utf.h are included into
18b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   utypes.h to provide all the general definitions for ICU.
19b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   All of these definitions used to be in utypes.h before
20b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*   the UTF-handling macros made this unmaintainable.
21b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru*/
22b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
23b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef __UMACHINE_H__
24b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define __UMACHINE_H__
25b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
26b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
27b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
28b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \file
29b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru * \brief Basic types and constants for UTF
30b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru *
31b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * <h2> Basic types and constants for UTF </h2>
32b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *   This file defines basic types and constants for utf.h to be
33b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *   platform-independent. umachine.h and utf.h are included into
34b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *   utypes.h to provide all the general definitions for ICU.
35b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *   All of these definitions used to be in utypes.h before
36b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *   the UTF-handling macros made this unmaintainable.
37b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru *
38b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
39b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
40b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* Include platform-dependent definitions                                   */
41b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* which are contained in the platform-specific file platform.h             */
42b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
43b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
44103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#include "unicode/ptypes.h" /* platform.h is included in ptypes.h */
45b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
46b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*
47b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * ANSI C headers:
48b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * stddef.h defines wchar_t
49b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
50b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#include <stddef.h>
51b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
52b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
53b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* For C wrappers, we use the symbol U_STABLE.                                */
54b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* This works properly if the includer is C or C++.                         */
55b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* Functions are declared   U_STABLE return-type U_EXPORT2 function-name()... */
56b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
57b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
58b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
59b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \def U_CFUNC
60b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * This is used in a declaration of a library private ICU C function.
61b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.4
62b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
63b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
64b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
65b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \def U_CDECL_BEGIN
66b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * This is used to begin a declaration of a library private ICU C API.
67b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.4
68b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
69b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
70b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
71b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \def U_CDECL_END
72b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru * This is used to end a declaration of a library private ICU C API
73b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.4
74b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
75b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
76103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#ifdef __cplusplus
77b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define U_CFUNC extern "C"
78b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define U_CDECL_BEGIN extern "C" {
79b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define U_CDECL_END   }
80b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#else
81b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define U_CFUNC extern
82b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define U_CDECL_BEGIN
83b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define U_CDECL_END
84b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
85b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
86b26ce3a7367e4ed2ee7ddddcdc3f3d3377a455c2claireho#ifndef U_ATTRIBUTE_DEPRECATED
8750294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho/**
8850294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho * \def U_ATTRIBUTE_DEPRECATED
8950294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho *  This is used for GCC specific attributes
9050294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho * @internal
9150294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho */
9254dcd9b6a06071f647dac967e9e267abb9410720Craig Cornelius#if U_GCC_MAJOR_MINOR >= 302
93b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#    define U_ATTRIBUTE_DEPRECATED __attribute__ ((deprecated))
9450294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho/**
9550294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho * \def U_ATTRIBUTE_DEPRECATED
9650294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho * This is used for Visual C++ specific attributes
9750294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho * @internal
9850294ead5e5d23f5bbfed76e00e6b510bd41eee1claireho */
99103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#elif defined(_MSC_VER) && (_MSC_VER >= 1400)
100b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#    define U_ATTRIBUTE_DEPRECATED __declspec(deprecated)
101b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#else
102b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#    define U_ATTRIBUTE_DEPRECATED
103b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#endif
104b26ce3a7367e4ed2ee7ddddcdc3f3d3377a455c2claireho#endif
105b26ce3a7367e4ed2ee7ddddcdc3f3d3377a455c2claireho
106b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** This is used to declare a function as a public ICU C API @stable ICU 2.0*/
107b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define U_CAPI U_CFUNC U_EXPORT
108b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru/** This is used to declare a function as a stable public ICU C API*/
109b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define U_STABLE U_CAPI
110b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru/** This is used to declare a function as a draft public ICU C API  */
111b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define U_DRAFT  U_CAPI
112b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru/** This is used to declare a function as a deprecated public ICU C API  */
113b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#define U_DEPRECATED U_CAPI U_ATTRIBUTE_DEPRECATED
114b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru/** This is used to declare a function as an obsolete public ICU C API  */
115b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define U_OBSOLETE U_CAPI
116b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru/** This is used to declare a function as an internal ICU C API  */
117b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define U_INTERNAL U_CAPI
118b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
119f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius/**
120f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * \def U_OVERRIDE
121f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * Defined to the C++11 "override" keyword if available.
122f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * Denotes a class or member which is an override of the base class.
123f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * May result in an error if it applied to something not an override.
124f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * @internal
125f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius */
126f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius
127f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius/**
128f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * \def U_FINAL
129f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * Defined to the C++11 "final" keyword if available.
130f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * Denotes a class or member which may not be overridden in subclasses.
131f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * May result in an error if subclasses attempt to override.
132f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius * @internal
133f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius */
134f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius
135c14898b482f76ecab9026615e2e4c6fe78358bdcFredrik Roubert#if U_CPLUSPLUS_VERSION >= 11
136f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius/* C++11 */
137f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#ifndef U_OVERRIDE
138f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#define U_OVERRIDE override
139f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#endif
140f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#ifndef U_FINAL
141f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#define U_FINAL final
142f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#endif
143f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#else
144f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius/* not C++11 - define to nothing */
145f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#ifndef U_OVERRIDE
146f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#define U_OVERRIDE
147f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#endif
148f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#ifndef U_FINAL
149f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#define U_FINAL
150f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#endif
151f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius#endif
152f9878a236aa0d9662d8e40cafdaf2e04cd615835ccornelius
153b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
154b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* limits for int32_t etc., like in POSIX inttypes.h                        */
155b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
156b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
157b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef INT8_MIN
158b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The smallest value an 8 bit signed integer can hold @stable ICU 2.0 */
159b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT8_MIN        ((int8_t)(-128))
160b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
161b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef INT16_MIN
162b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The smallest value a 16 bit signed integer can hold @stable ICU 2.0 */
163b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT16_MIN       ((int16_t)(-32767-1))
164b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
165b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef INT32_MIN
166b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The smallest value a 32 bit signed integer can hold @stable ICU 2.0 */
167b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT32_MIN       ((int32_t)(-2147483647-1))
168b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
169b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
170b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef INT8_MAX
171b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value an 8 bit signed integer can hold @stable ICU 2.0 */
172b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT8_MAX        ((int8_t)(127))
173b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
174b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef INT16_MAX
175b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value a 16 bit signed integer can hold @stable ICU 2.0 */
176b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT16_MAX       ((int16_t)(32767))
177b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
178b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef INT32_MAX
179b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value a 32 bit signed integer can hold @stable ICU 2.0 */
180b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT32_MAX       ((int32_t)(2147483647))
181b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
182b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
183b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef UINT8_MAX
184b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value an 8 bit unsigned integer can hold @stable ICU 2.0 */
185b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define UINT8_MAX       ((uint8_t)(255U))
186b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
187b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef UINT16_MAX
188b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value a 16 bit unsigned integer can hold @stable ICU 2.0 */
189b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define UINT16_MAX      ((uint16_t)(65535U))
190b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
191b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef UINT32_MAX
192b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value a 32 bit unsigned integer can hold @stable ICU 2.0 */
193b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define UINT32_MAX      ((uint32_t)(4294967295U))
194b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
195b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
196b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#if defined(U_INT64_T_UNAVAILABLE)
197b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# error int64_t is required for decimal format and rule-based number format.
198b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#else
199b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# ifndef INT64_C
200b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
201b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * Provides a platform independent way to specify a signed 64-bit integer constant.
202b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * note: may be wrong for some 64 bit platforms - ensure your compiler provides INT64_C
203b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.8
204b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
205b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define INT64_C(c) c ## LL
206b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# endif
207b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# ifndef UINT64_C
208b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
209b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * Provides a platform independent way to specify an unsigned 64-bit integer constant.
210b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * note: may be wrong for some 64 bit platforms - ensure your compiler provides UINT64_C
211b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.8
212b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
213b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define UINT64_C(c) c ## ULL
214b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# endif
215b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# ifndef U_INT64_MIN
216b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The smallest value a 64 bit signed integer can hold @stable ICU 2.8 */
217b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#     define U_INT64_MIN       ((int64_t)(INT64_C(-9223372036854775807)-1))
218b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# endif
219b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# ifndef U_INT64_MAX
220b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value a 64 bit signed integer can hold @stable ICU 2.8 */
221b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#     define U_INT64_MAX       ((int64_t)(INT64_C(9223372036854775807)))
222b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# endif
223b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# ifndef U_UINT64_MAX
224b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The largest value a 64 bit unsigned integer can hold @stable ICU 2.8 */
225b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#     define U_UINT64_MAX      ((uint64_t)(UINT64_C(18446744073709551615)))
226b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru# endif
227b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
228b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
229b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
230b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* Boolean data type                                                        */
231b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
232b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
233b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The ICU boolean type @stable ICU 2.0 */
234b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Querutypedef int8_t UBool;
235b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
236b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef TRUE
237b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The TRUE value of a UBool @stable ICU 2.0 */
238b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define TRUE  1
239b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
240b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#ifndef FALSE
241b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** The FALSE value of a UBool @stable ICU 2.0 */
242b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   define FALSE 0
243b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
244b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
245b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
246b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
247b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* Unicode data types                                                       */
248b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*==========================================================================*/
249b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
250b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* wchar_t-related definitions -------------------------------------------- */
251b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
252b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*
253b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \def U_WCHAR_IS_UTF16
254b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * Defined if wchar_t uses UTF-16.
255b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *
256b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.0
257b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
258b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/*
259b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \def U_WCHAR_IS_UTF32
260b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * Defined if wchar_t uses UTF-32.
261b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *
262b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.0
263b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
264b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#if !defined(U_WCHAR_IS_UTF16) && !defined(U_WCHAR_IS_UTF32)
265b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#   ifdef __STDC_ISO_10646__
266b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#       if (U_SIZEOF_WCHAR_T==2)
267b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#           define U_WCHAR_IS_UTF16
268b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#       elif (U_SIZEOF_WCHAR_T==4)
269b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#           define  U_WCHAR_IS_UTF32
270b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#       endif
271b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   elif defined __UCS2__
272103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#       if (U_PF_OS390 <= U_PLATFORM && U_PLATFORM <= U_PF_OS400) && (U_SIZEOF_WCHAR_T==2)
273b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#           define U_WCHAR_IS_UTF16
274b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#       endif
275103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#   elif defined(__UCS4__) || (U_PLATFORM == U_PF_OS400 && defined(__UTF32__))
276b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#       if (U_SIZEOF_WCHAR_T==4)
277b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#           define U_WCHAR_IS_UTF32
278b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#       endif
279103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#   elif U_PLATFORM_IS_DARWIN_BASED || (U_SIZEOF_WCHAR_T==4 && U_PLATFORM_IS_LINUX_BASED)
280103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#       define U_WCHAR_IS_UTF32
281103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#   elif U_PLATFORM_HAS_WIN32_API
282b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru#       define U_WCHAR_IS_UTF16
283b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#   endif
284b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
285b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
286b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/* UChar and UChar32 definitions -------------------------------------------- */
287b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
288b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/** Number of bytes in a UChar. @stable ICU 2.0 */
289b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#define U_SIZEOF_UCHAR 2
290b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
291b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
292b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * \var UChar
29354dcd9b6a06071f647dac967e9e267abb9410720Craig Cornelius * Define UChar to be UCHAR_TYPE, if that is #defined (for example, to char16_t),
294103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * or wchar_t if that is 16 bits wide; always assumed to be unsigned.
295103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * If neither is available, then define UChar to be uint16_t.
296103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius *
297b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * This makes the definition of UChar platform-dependent
298b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * but allows direct string type compatibility with platforms with
299b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * 16-bit wchar_t types.
300b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *
301103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * @stable ICU 4.4
302b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
30354dcd9b6a06071f647dac967e9e267abb9410720Craig Cornelius#if defined(UCHAR_TYPE)
30454dcd9b6a06071f647dac967e9e267abb9410720Craig Cornelius    typedef UCHAR_TYPE UChar;
30554dcd9b6a06071f647dac967e9e267abb9410720Craig Cornelius/* Not #elif U_HAVE_CHAR16_T -- because that is type-incompatible with pre-C++11 callers
30654dcd9b6a06071f647dac967e9e267abb9410720Craig Cornelius    typedef char16_t UChar;  */
307103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#elif U_SIZEOF_WCHAR_T==2
308103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius    typedef wchar_t UChar;
309103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#elif defined(__CHAR16_TYPE__)
310103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius    typedef __CHAR16_TYPE__ UChar;
311b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#else
312b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru    typedef uint16_t UChar;
313b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
314b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
315b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
316b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * Define UChar32 as a type for single Unicode code points.
317b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * UChar32 is a signed 32-bit integer (same as int32_t).
318b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *
319b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * The Unicode code point range is 0..0x10ffff.
320b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * All other values (negative or >=0x110000) are illegal as Unicode code points.
321b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * They may be used as sentinel values to indicate "done", "error"
322b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * or similar non-code point conditions.
323b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *
324b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * Before ICU 2.4 (Jitterbug 2146), UChar32 was defined
325b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * to be wchar_t if that is 32 bits wide (wchar_t may be signed or unsigned)
326b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * or else to be uint32_t.
327b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * That is, the definition of UChar32 was platform-dependent.
328b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru *
329b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @see U_SENTINEL
330b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru * @stable ICU 2.4
331b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru */
332b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Querutypedef int32_t UChar32;
333b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
334b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru/**
335103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * This value is intended for sentinel values for APIs that
336103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * (take or) return single code points (UChar32).
337103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * It is outside of the Unicode code point range 0..0x10ffff.
338103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius *
339103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * For example, a "done" or "error" value in a new API
340103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * could be indicated with U_SENTINEL.
341103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius *
342103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * ICU APIs designed before ICU 2.4 usually define service-specific "done"
343103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * values, mostly 0xffff.
344103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * Those may need to be distinguished from
345103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * actual U+ffff text contents by calling functions like
346103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * CharacterIterator::hasNext() or UnicodeString::length().
347103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius *
348103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * @return -1
349103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * @see UChar32
350103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius * @stable ICU 2.4
351b0ac937921a2c196d8b9da665135bf6ba01a1ccfJean-Baptiste Queru */
352103e9ffba2cba345d0078eb8b8db33249f81840aCraig Cornelius#define U_SENTINEL (-1)
353b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
354b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#include "unicode/urename.h"
355b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru
356b13da9df870a61b11249bf741347908dbea0edd8Jean-Baptiste Queru#endif
357