ICU 78.1  78.1
platform.h
Go to the documentation of this file.
1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 ******************************************************************************
5 *
6 * Copyright (C) 1997-2016, International Business Machines
7 * Corporation and others. All Rights Reserved.
8 *
9 ******************************************************************************
10 *
11 * FILE NAME : platform.h
12 *
13 * Date Name Description
14 * 05/13/98 nos Creation (content moved here from ptypes.h).
15 * 03/02/99 stephen Added AS400 support.
16 * 03/30/99 stephen Added Linux support.
17 * 04/13/99 stephen Reworked for autoconf.
18 ******************************************************************************
19 */
20 
21 #ifndef _PLATFORM_H
22 #define _PLATFORM_H
23 
24 #include "unicode/uconfig.h"
25 #include "unicode/uvernum.h"
26 
59 #ifdef U_IN_DOXYGEN
60 /*
61  * Problem: "platform.h:335: warning: documentation for unknown define U_HAVE_STD_STRING found." means that U_HAVE_STD_STRING is not documented.
62  * Solution: #define any defines for non @internal API here, so that they are visible in the docs. If you just set PREDEFINED in Doxyfile.in, they won't be documented.
63  */
64 
65 /* None for now. */
66 #endif
67 
89 #define U_PF_UNKNOWN 0
91 #define U_PF_WINDOWS 1000
93 #define U_PF_MINGW 1800
99 #define U_PF_CYGWIN 1900
100 /* Reserve 2000 for U_PF_UNIX? */
102 #define U_PF_HPUX 2100
104 #define U_PF_SOLARIS 2600
106 #define U_PF_BSD 3000
108 #define U_PF_AIX 3100
110 #define U_PF_IRIX 3200
119 #define U_PF_DARWIN 3500
121 #define U_PF_IPHONE 3550
123 #define U_PF_QNX 3700
125 #define U_PF_LINUX 4000
132 #define U_PF_BROWSER_NATIVE_CLIENT 4020
134 #define U_PF_ANDROID 4050
136 #define U_PF_HAIKU 4080
138 #define U_PF_FUCHSIA 4100
139 /* Maximum value for Linux-based platform is 4499 */
147 #define U_PF_EMSCRIPTEN 5010
149 #define U_PF_OS390 9000
151 #define U_PF_OS400 9400
152 
153 #ifdef U_PLATFORM
154  /* Use the predefined value. */
155 #elif defined(__MINGW32__)
156 # define U_PLATFORM U_PF_MINGW
157 #elif defined(__CYGWIN__)
158 # define U_PLATFORM U_PF_CYGWIN
159  /* Cygwin uchar.h doesn't exist until Cygwin 3.5. */
160 # include <cygwin/version.h>
161 #elif defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
162 # define U_PLATFORM U_PF_WINDOWS
163 #elif defined(__ANDROID__)
164 # define U_PLATFORM U_PF_ANDROID
165  /* Android wchar_t support depends on the API level. */
166 # include <android/api-level.h>
167 #elif defined(__pnacl__) || defined(__native_client__)
168 # define U_PLATFORM U_PF_BROWSER_NATIVE_CLIENT
169 #elif defined(__Fuchsia__)
170 # define U_PLATFORM U_PF_FUCHSIA
171 #elif defined(linux) || defined(__linux__) || defined(__linux)
172 # define U_PLATFORM U_PF_LINUX
173 #elif defined(__APPLE__) && defined(__MACH__)
174 # include <TargetConditionals.h>
175 # if (defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE) && (defined(TARGET_OS_MACCATALYST) && !TARGET_OS_MACCATALYST) /* variant of TARGET_OS_MAC */
176 # define U_PLATFORM U_PF_IPHONE
177 # else
178 # define U_PLATFORM U_PF_DARWIN
179 # endif
180 #elif defined(BSD) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__MirBSD__)
181 # if defined(__FreeBSD__)
182 # include <sys/endian.h>
183 # endif
184 # define U_PLATFORM U_PF_BSD
185 #elif defined(sun) || defined(__sun)
186  /* Check defined(__SVR4) || defined(__svr4__) to distinguish Solaris from SunOS? */
187 # define U_PLATFORM U_PF_SOLARIS
188 # if defined(__GNUC__)
189  /* Solaris/GCC needs this header file to get the proper endianness. Normally, this
190  * header file is included with stddef.h but on Solairs/GCC, the GCC version of stddef.h
191  * is included which does not include this header file.
192  */
193 # include <sys/isa_defs.h>
194 # endif
195 #elif defined(_AIX) || defined(__TOS_AIX__)
196 # define U_PLATFORM U_PF_AIX
197 #elif defined(_hpux) || defined(hpux) || defined(__hpux)
198 # define U_PLATFORM U_PF_HPUX
199 #elif defined(sgi) || defined(__sgi)
200 # define U_PLATFORM U_PF_IRIX
201 #elif defined(__QNX__) || defined(__QNXNTO__)
202 # define U_PLATFORM U_PF_QNX
203 #elif defined(__TOS_MVS__)
204 # define U_PLATFORM U_PF_OS390
205 #elif defined(__OS400__) || defined(__TOS_OS400__)
206 # define U_PLATFORM U_PF_OS400
207 #elif defined(__HAIKU__)
208 # define U_PLATFORM U_PF_HAIKU
209 #elif defined(__EMSCRIPTEN__)
210 # define U_PLATFORM U_PF_EMSCRIPTEN
211 #else
212 # define U_PLATFORM U_PF_UNKNOWN
213 #endif
214 
222 #if (defined(_MSC_VER) && !(defined(__clang__) && __clang__)) || defined(U_IN_DOXYGEN)
223 # define U_REAL_MSVC
224 #endif
225 
232 /* Commented out because this is already set in mh-cygwin-msvc
233 #if U_PLATFORM == U_PF_CYGWIN && defined(_MSC_VER)
234 # define CYGWINMSVC
235 #endif
236 */
237 #ifdef U_IN_DOXYGEN
238 # define CYGWINMSVC
239 #endif
240 
247 #ifdef U_PLATFORM_USES_ONLY_WIN32_API
248  /* Use the predefined value. */
249 #elif (U_PF_WINDOWS <= U_PLATFORM && U_PLATFORM <= U_PF_MINGW) || defined(CYGWINMSVC)
250 # define U_PLATFORM_USES_ONLY_WIN32_API 1
251 #else
252  /* Cygwin implements POSIX. */
253 # define U_PLATFORM_USES_ONLY_WIN32_API 0
254 #endif
255 
262 #ifdef U_PLATFORM_HAS_WIN32_API
263  /* Use the predefined value. */
264 #elif U_PF_WINDOWS <= U_PLATFORM && U_PLATFORM <= U_PF_CYGWIN
265 # define U_PLATFORM_HAS_WIN32_API 1
266 #else
267 # define U_PLATFORM_HAS_WIN32_API 0
268 #endif
269 
276 #ifdef U_PLATFORM_HAS_WINUWP_API
277  /* Use the predefined value. */
278 #else
279 # define U_PLATFORM_HAS_WINUWP_API 0
280 #endif
281 
288 #ifdef U_PLATFORM_IMPLEMENTS_POSIX
289  /* Use the predefined value. */
290 #elif U_PLATFORM_USES_ONLY_WIN32_API
291 # define U_PLATFORM_IMPLEMENTS_POSIX 0
292 #else
293 # define U_PLATFORM_IMPLEMENTS_POSIX 1
294 #endif
295 
301 #ifdef U_PLATFORM_IS_LINUX_BASED
302  /* Use the predefined value. */
303 #elif U_PF_LINUX <= U_PLATFORM && U_PLATFORM <= 4499
304 # define U_PLATFORM_IS_LINUX_BASED 1
305 #else
306 # define U_PLATFORM_IS_LINUX_BASED 0
307 #endif
308 
314 #ifdef U_PLATFORM_IS_DARWIN_BASED
315  /* Use the predefined value. */
316 #elif U_PF_DARWIN <= U_PLATFORM && U_PLATFORM <= U_PF_IPHONE
317 # define U_PLATFORM_IS_DARWIN_BASED 1
318 #else
319 # define U_PLATFORM_IS_DARWIN_BASED 0
320 #endif
321 
322 /*===========================================================================*/
324 /*===========================================================================*/
325 
336 #ifdef __GNUC__
337 # define U_GCC_MAJOR_MINOR (__GNUC__ * 100 + __GNUC_MINOR__)
338 #else
339 # define U_GCC_MAJOR_MINOR 0
340 #endif
341 
347 #ifdef U_IS_BIG_ENDIAN
348  /* Use the predefined value. */
349 #elif defined(BYTE_ORDER) && defined(BIG_ENDIAN)
350 # define U_IS_BIG_ENDIAN (BYTE_ORDER == BIG_ENDIAN)
351 #elif defined(__BYTE_ORDER__) && defined(__ORDER_BIG_ENDIAN__)
352  /* gcc */
353 # define U_IS_BIG_ENDIAN (__BYTE_ORDER__ == __ORDER_BIG_ENDIAN__)
354 #elif defined(__BIG_ENDIAN__) || defined(_BIG_ENDIAN)
355 # define U_IS_BIG_ENDIAN 1
356 #elif defined(__LITTLE_ENDIAN__) || defined(_LITTLE_ENDIAN)
357 # define U_IS_BIG_ENDIAN 0
358 #elif U_PLATFORM == U_PF_OS390 || U_PLATFORM == U_PF_OS400 || defined(__s390__) || defined(__s390x__)
359  /* These platforms do not appear to predefine any endianness macros. */
360 # define U_IS_BIG_ENDIAN 1
361 #elif defined(_PA_RISC1_0) || defined(_PA_RISC1_1) || defined(_PA_RISC2_0)
362  /* HPPA do not appear to predefine any endianness macros. */
363 # define U_IS_BIG_ENDIAN 1
364 #elif defined(sparc) || defined(__sparc) || defined(__sparc__)
365  /* Some sparc based systems (e.g. Linux) do not predefine any endianness macros. */
366 # define U_IS_BIG_ENDIAN 1
367 #else
368 # define U_IS_BIG_ENDIAN 0
369 #endif
370 
377 #ifdef U_HAVE_DEBUG_LOCATION_NEW
378  /* Use the predefined value. */
379 #elif defined(_MSC_VER)
380 # define U_HAVE_DEBUG_LOCATION_NEW 1
381 #else
382 # define U_HAVE_DEBUG_LOCATION_NEW 0
383 #endif
384 
385 /* Compatibility with compilers other than clang: http://clang.llvm.org/docs/LanguageExtensions.html */
386 #ifdef __has_attribute
387 # define UPRV_HAS_ATTRIBUTE(x) __has_attribute(x)
388 #else
389 # define UPRV_HAS_ATTRIBUTE(x) 0
390 #endif
391 #ifdef __has_cpp_attribute
392 # define UPRV_HAS_CPP_ATTRIBUTE(x) __has_cpp_attribute(x)
393 #else
394 # define UPRV_HAS_CPP_ATTRIBUTE(x) 0
395 #endif
396 #ifdef __has_declspec_attribute
397 # define UPRV_HAS_DECLSPEC_ATTRIBUTE(x) __has_declspec_attribute(x)
398 #else
399 # define UPRV_HAS_DECLSPEC_ATTRIBUTE(x) 0
400 #endif
401 #ifdef __has_builtin
402 # define UPRV_HAS_BUILTIN(x) __has_builtin(x)
403 #else
404 # define UPRV_HAS_BUILTIN(x) 0
405 #endif
406 #ifdef __has_feature
407 # define UPRV_HAS_FEATURE(x) __has_feature(x)
408 #else
409 # define UPRV_HAS_FEATURE(x) 0
410 #endif
411 #ifdef __has_extension
412 # define UPRV_HAS_EXTENSION(x) __has_extension(x)
413 #else
414 # define UPRV_HAS_EXTENSION(x) 0
415 #endif
416 #ifdef __has_warning
417 # define UPRV_HAS_WARNING(x) __has_warning(x)
418 #else
419 # define UPRV_HAS_WARNING(x) 0
420 #endif
421 
422 
423 #if defined(__clang__)
424 #define UPRV_NO_SANITIZE_UNDEFINED __attribute__((no_sanitize("undefined")))
425 #else
426 #define UPRV_NO_SANITIZE_UNDEFINED
427 #endif
428 
434 #if defined(__GNUC__) && __GNUC__>=3
435 # define U_MALLOC_ATTR __attribute__ ((__malloc__))
436 #else
437 # define U_MALLOC_ATTR
438 #endif
439 
445 #if (defined(__GNUC__) && \
446  (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3))) || \
447  UPRV_HAS_ATTRIBUTE(alloc_size)
448 # define U_ALLOC_SIZE_ATTR(X) __attribute__ ((alloc_size(X)))
449 # define U_ALLOC_SIZE_ATTR2(X,Y) __attribute__ ((alloc_size(X,Y)))
450 #else
451 # define U_ALLOC_SIZE_ATTR(X)
452 # define U_ALLOC_SIZE_ATTR2(X,Y)
453 #endif
454 
461 #ifdef U_CPLUSPLUS_VERSION
462 # if U_CPLUSPLUS_VERSION != 0 && !defined(__cplusplus)
463 # undef U_CPLUSPLUS_VERSION
464 # define U_CPLUSPLUS_VERSION 0
465 # endif
466  /* Otherwise use the predefined value. */
467 #elif !defined(__cplusplus)
468 # define U_CPLUSPLUS_VERSION 0
469 // The value of _MSVC_LANG for C++23 preview is undocumented, except that it is larger than 202002.
470 // As of this writing, it is 202004.
471 #elif __cplusplus >= 202302L || (defined(_MSVC_LANG) && _MSVC_LANG > 202002L)
472 # define U_CPLUSPLUS_VERSION 23
473 #elif __cplusplus >= 202002L || (defined(_MSVC_LANG) && _MSVC_LANG >= 202002L)
474 # define U_CPLUSPLUS_VERSION 20
475 #elif __cplusplus >= 201703L || (defined(_MSVC_LANG) && _MSVC_LANG >= 201703L)
476 # define U_CPLUSPLUS_VERSION 17
477 #elif __cplusplus >= 201402L || (defined(_MSVC_LANG) && _MSVC_LANG >= 201402L)
478 # define U_CPLUSPLUS_VERSION 14
479 #elif __cplusplus >= 201103L || (defined(_MSVC_LANG) && _MSVC_LANG >= 201103L)
480 # define U_CPLUSPLUS_VERSION 11
481 #else
482  // C++98 or C++03
483 # define U_CPLUSPLUS_VERSION 1
484 #endif
485 
492 #if defined(U_FALLTHROUGH)
493  // Use the predefined value.
494 #elif defined(__clang__)
495  // Test for compiler vs. feature separately.
496  // Other compilers might choke on the feature test.
497 # if UPRV_HAS_CPP_ATTRIBUTE(clang::fallthrough) || \
498  (UPRV_HAS_FEATURE(cxx_attributes) && \
499  UPRV_HAS_WARNING("-Wimplicit-fallthrough"))
500 # define U_FALLTHROUGH [[clang::fallthrough]]
501 # endif
502 #elif defined(__GNUC__) && (__GNUC__ >= 7)
503 # define U_FALLTHROUGH __attribute__((fallthrough))
504 #endif
505 
506 #ifndef U_FALLTHROUGH
507 # define U_FALLTHROUGH
508 #endif
509 
512 /*===========================================================================*/
514 /*===========================================================================*/
515 
520 #define U_ASCII_FAMILY 0
521 
526 #define U_EBCDIC_FAMILY 1
527 
570 #ifdef U_CHARSET_FAMILY
571  /* Use the predefined value. */
572 #elif U_PLATFORM == U_PF_OS390 && (!defined(__CHARSET_LIB) || !__CHARSET_LIB)
573 # define U_CHARSET_FAMILY U_EBCDIC_FAMILY
574 #elif U_PLATFORM == U_PF_OS400 && !defined(__UTF32__)
575 # define U_CHARSET_FAMILY U_EBCDIC_FAMILY
576 #else
577 # define U_CHARSET_FAMILY U_ASCII_FAMILY
578 #endif
579 
600 #ifdef U_CHARSET_IS_UTF8
601  /* Use the predefined value. */
602 #elif U_PLATFORM_IS_LINUX_BASED || U_PLATFORM_IS_DARWIN_BASED || \
603  U_PLATFORM == U_PF_EMSCRIPTEN
604 # define U_CHARSET_IS_UTF8 1
605 #else
606 # define U_CHARSET_IS_UTF8 0
607 #endif
608 
611 /*===========================================================================*/
613 /*===========================================================================*/
614 
621 #ifdef U_HAVE_WCHAR_H
622  /* Use the predefined value. */
623 #elif U_PLATFORM == U_PF_ANDROID && __ANDROID_API__ < 9
624  /*
625  * Android before Gingerbread (Android 2.3, API level 9) did not support wchar_t.
626  * The type and header existed, but the library functions did not work as expected.
627  * The size of wchar_t was 1 but L"xyz" string literals had 32-bit units anyway.
628  */
629 # define U_HAVE_WCHAR_H 0
630 #else
631 # define U_HAVE_WCHAR_H 1
632 #endif
633 
640 #ifdef U_SIZEOF_WCHAR_T
641  /* Use the predefined value. */
642 #elif (U_PLATFORM == U_PF_ANDROID && __ANDROID_API__ < 9)
643  /*
644  * Classic Mac OS and Mac OS X before 10.3 (Panther) did not support wchar_t or wstring.
645  * Newer Mac OS X has size 4.
646  */
647 # define U_SIZEOF_WCHAR_T 1
648 #elif U_PLATFORM_HAS_WIN32_API || U_PLATFORM == U_PF_CYGWIN
649 # define U_SIZEOF_WCHAR_T 2
650 #elif U_PLATFORM == U_PF_AIX
651  /*
652  * AIX 6.1 information, section "Wide character data representation":
653  * "... the wchar_t datatype is 32-bit in the 64-bit environment and
654  * 16-bit in the 32-bit environment."
655  * and
656  * "All locales use Unicode for their wide character code values (process code),
657  * except the IBM-eucTW codeset."
658  */
659 # ifdef __64BIT__
660 # define U_SIZEOF_WCHAR_T 4
661 # else
662 # define U_SIZEOF_WCHAR_T 2
663 # endif
664 #elif U_PLATFORM == U_PF_OS390
665  /*
666  * z/OS V1R11 information center, section "LP64 | ILP32":
667  * "In 31-bit mode, the size of long and pointers is 4 bytes and the size of wchar_t is 2 bytes.
668  * Under LP64, the size of long and pointer is 8 bytes and the size of wchar_t is 4 bytes."
669  */
670 # ifdef _LP64
671 # define U_SIZEOF_WCHAR_T 4
672 # else
673 # define U_SIZEOF_WCHAR_T 2
674 # endif
675 #elif U_PLATFORM == U_PF_OS400
676 # if defined(__UTF32__)
677  /*
678  * LOCALETYPE(*LOCALEUTF) is specified.
679  * Wide-character strings are in UTF-32,
680  * narrow-character strings are in UTF-8.
681  */
682 # define U_SIZEOF_WCHAR_T 4
683 # elif defined(__UCS2__)
684  /*
685  * LOCALETYPE(*LOCALEUCS2) is specified.
686  * Wide-character strings are in UCS-2,
687  * narrow-character strings are in EBCDIC.
688  */
689 # define U_SIZEOF_WCHAR_T 2
690 # else
691  /*
692  * LOCALETYPE(*CLD) or LOCALETYPE(*LOCALE) is specified.
693  * Wide-character strings are in 16-bit EBCDIC,
694  * narrow-character strings are in EBCDIC.
695  */
696 # define U_SIZEOF_WCHAR_T 2
697 # endif
698 #else
699 # define U_SIZEOF_WCHAR_T 4
700 #endif
701 
702 #ifndef U_HAVE_WCSCPY
703 #define U_HAVE_WCSCPY U_HAVE_WCHAR_H
704 #endif
705 
716 #ifdef U_HAVE_CHAR16_T
717  /* Use the predefined value. */
718 #else
719  /*
720  * Notes:
721  * C++11 and C11 require support for UTF-16 literals
722  * Doesn't work on Mac C11 (see workaround in ptypes.h)
723  * or Cygwin less than 3.5.
724  */
725 # if defined(__cplusplus)
726 # define U_HAVE_CHAR16_T 1
727 # elif U_PLATFORM_IS_DARWIN_BASED || (U_PLATFORM == U_PF_CYGWIN && CYGWIN_VERSION_DLL_MAJOR < 3005)
728 # define U_HAVE_CHAR16_T 0
729 # else
730  // conformant C11
731 # define U_HAVE_CHAR16_T 1
732 # endif
733 #endif
734 
744 #ifdef U_DECLARE_UTF16
745  /* Use the predefined value. */
746 #elif U_HAVE_CHAR16_T \
747  || (defined(__xlC__) && defined(__IBM_UTF_LITERAL) && U_SIZEOF_WCHAR_T != 2) \
748  || (defined(__HP_aCC) && __HP_aCC >= 035000) \
749  || (defined(__HP_cc) && __HP_cc >= 111106) \
750  || (defined(U_IN_DOXYGEN))
751 # define U_DECLARE_UTF16(string) u ## string
752 #elif U_SIZEOF_WCHAR_T == 2 \
753  && (U_CHARSET_FAMILY == 0 || (U_PF_OS390 <= U_PLATFORM && U_PLATFORM <= U_PF_OS400 && defined(__UCS2__)))
754 # define U_DECLARE_UTF16(string) L ## string
755 #else
756  /* Leave U_DECLARE_UTF16 undefined. See unistr.h. */
757 #endif
758 
761 /*===========================================================================*/
763 /*===========================================================================*/
764 
765 #ifdef U_EXPORT
766  /* Use the predefined value. */
767 #elif defined(U_STATIC_IMPLEMENTATION)
768 # define U_EXPORT
769 #elif defined(_MSC_VER) || (UPRV_HAS_DECLSPEC_ATTRIBUTE(__dllexport__) && \
770  UPRV_HAS_DECLSPEC_ATTRIBUTE(__dllimport__))
771 # define U_EXPORT __declspec(dllexport)
772 #elif defined(__GNUC__) || defined(__open_xl__)
773 # define U_EXPORT __attribute__((visibility("default")))
774 #elif (defined(__SUNPRO_CC) && __SUNPRO_CC >= 0x550) \
775  || (defined(__SUNPRO_C) && __SUNPRO_C >= 0x550)
776 # define U_EXPORT __global
777 /*#elif defined(__HP_aCC) || defined(__HP_cc)
778 # define U_EXPORT __declspec(dllexport)*/
779 #else
780 # define U_EXPORT
781 #endif
782 
783 /* U_CALLCONV is related to U_EXPORT2 */
784 #ifdef U_EXPORT2
785  /* Use the predefined value. */
786 #elif defined(_MSC_VER)
787 # define U_EXPORT2 __cdecl
788 #else
789 # define U_EXPORT2
790 #endif
791 
792 #ifdef U_IMPORT
793  /* Use the predefined value. */
794 #elif defined(_MSC_VER) || (UPRV_HAS_DECLSPEC_ATTRIBUTE(__dllexport__) && \
795  UPRV_HAS_DECLSPEC_ATTRIBUTE(__dllimport__))
796  /* Windows needs to export/import data. */
797 # define U_IMPORT __declspec(dllimport)
798 #else
799 # define U_IMPORT
800 #endif
801 
809 #ifdef U_HIDDEN
810  /* Use the predefined value. */
811 #elif defined(__GNUC__) || defined(__open_xl__)
812 # define U_HIDDEN __attribute__((visibility("hidden")))
813 #else
814 # define U_HIDDEN
815 #endif
816 
834 #if U_PLATFORM == U_PF_OS390 && defined(__cplusplus)
835 # define U_CALLCONV __cdecl
836 #else
837 # define U_CALLCONV U_EXPORT2
838 #endif
839 
845 #if U_PLATFORM == U_PF_OS390 && defined(__cplusplus)
846 # define U_CALLCONV_FPTR U_CALLCONV
847 #else
848 # define U_CALLCONV_FPTR
849 #endif
852 #endif // _PLATFORM_H
User-configurable settings.
C API: definitions of ICU version numbers.