williamr@2: // boost cstdint.hpp header file ------------------------------------------// williamr@2: williamr@2: // (C) Copyright Beman Dawes 1999. williamr@2: // (C) Copyright Jens Mauer 2001 williamr@2: // (C) Copyright John Maddock 2001 williamr@2: // Distributed under the Boost williamr@2: // Software License, Version 1.0. (See accompanying file williamr@2: // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) williamr@2: williamr@2: // See http://www.boost.org/libs/integer for documentation. williamr@2: williamr@2: // Revision History williamr@2: // 31 Oct 01 use BOOST_HAS_LONG_LONG to check for "long long" (Jens M.) williamr@2: // 16 Apr 01 check LONGLONG_MAX when looking for "long long" (Jens Maurer) williamr@2: // 23 Jan 01 prefer "long" over "int" for int32_t and intmax_t (Jens Maurer) williamr@2: // 12 Nov 00 Merged (Jens Maurer) williamr@2: // 23 Sep 00 Added INTXX_C macro support (John Maddock). williamr@2: // 22 Sep 00 Better 64-bit support (John Maddock) williamr@2: // 29 Jun 00 Reimplement to avoid including stdint.h within namespace boost williamr@2: // 8 Aug 99 Initial version (Beman Dawes) williamr@2: williamr@2: williamr@2: #ifndef BOOST_CSTDINT_HPP williamr@2: #define BOOST_CSTDINT_HPP williamr@2: williamr@2: #include williamr@2: williamr@2: williamr@2: #ifdef BOOST_HAS_STDINT_H williamr@2: williamr@2: // The following #include is an implementation artifact; not part of interface. williamr@2: # ifdef __hpux williamr@2: // HP-UX has a vaguely nice in a non-standard location williamr@2: # include williamr@2: # ifdef __STDC_32_MODE__ williamr@2: // this is triggered with GCC, because it defines __cplusplus < 199707L williamr@2: # define BOOST_NO_INT64_T williamr@2: # endif williamr@2: # elif defined(__FreeBSD__) || defined(__IBMCPP__) williamr@2: # include williamr@2: # else williamr@2: # include williamr@2: williamr@2: // There is a bug in Cygwin two _C macros williamr@2: # if defined(__STDC_CONSTANT_MACROS) && defined(__CYGWIN__) williamr@2: # undef INTMAX_C williamr@2: # undef UINTMAX_C williamr@2: # define INTMAX_C(c) c##LL williamr@2: # define UINTMAX_C(c) c##ULL williamr@2: # endif williamr@2: williamr@2: # endif williamr@2: williamr@2: #ifdef __QNX__ williamr@2: williamr@2: // QNX (Dinkumware stdlib) defines these as non-standard names. williamr@2: // Reflect to the standard names. williamr@2: williamr@2: typedef ::intleast8_t int_least8_t; williamr@2: typedef ::intfast8_t int_fast8_t; williamr@2: typedef ::uintleast8_t uint_least8_t; williamr@2: typedef ::uintfast8_t uint_fast8_t; williamr@2: williamr@2: typedef ::intleast16_t int_least16_t; williamr@2: typedef ::intfast16_t int_fast16_t; williamr@2: typedef ::uintleast16_t uint_least16_t; williamr@2: typedef ::uintfast16_t uint_fast16_t; williamr@2: williamr@2: typedef ::intleast32_t int_least32_t; williamr@2: typedef ::intfast32_t int_fast32_t; williamr@2: typedef ::uintleast32_t uint_least32_t; williamr@2: typedef ::uintfast32_t uint_fast32_t; williamr@2: williamr@2: # ifndef BOOST_NO_INT64_T williamr@2: williamr@2: typedef ::intleast64_t int_least64_t; williamr@2: typedef ::intfast64_t int_fast64_t; williamr@2: typedef ::uintleast64_t uint_least64_t; williamr@2: typedef ::uintfast64_t uint_fast64_t; williamr@2: williamr@2: # endif williamr@2: williamr@2: #endif williamr@2: williamr@2: namespace boost williamr@2: { williamr@2: williamr@2: using ::int8_t; williamr@2: using ::int_least8_t; williamr@2: using ::int_fast8_t; williamr@2: using ::uint8_t; williamr@2: using ::uint_least8_t; williamr@2: using ::uint_fast8_t; williamr@2: williamr@2: using ::int16_t; williamr@2: using ::int_least16_t; williamr@2: using ::int_fast16_t; williamr@2: using ::uint16_t; williamr@2: using ::uint_least16_t; williamr@2: using ::uint_fast16_t; williamr@2: williamr@2: using ::int32_t; williamr@2: using ::int_least32_t; williamr@2: using ::int_fast32_t; williamr@2: using ::uint32_t; williamr@2: using ::uint_least32_t; williamr@2: using ::uint_fast32_t; williamr@2: williamr@2: # ifndef BOOST_NO_INT64_T williamr@2: williamr@2: using ::int64_t; williamr@2: using ::int_least64_t; williamr@2: using ::int_fast64_t; williamr@2: using ::uint64_t; williamr@2: using ::uint_least64_t; williamr@2: using ::uint_fast64_t; williamr@2: williamr@2: # endif williamr@2: williamr@2: using ::intmax_t; williamr@2: using ::uintmax_t; williamr@2: williamr@2: } // namespace boost williamr@2: williamr@2: #elif defined(__FreeBSD__) && (__FreeBSD__ <= 4) || defined(__osf__) williamr@2: // FreeBSD and Tru64 have an that contains much of what we need. williamr@2: # include williamr@2: williamr@2: namespace boost { williamr@2: williamr@2: using ::int8_t; williamr@2: typedef int8_t int_least8_t; williamr@2: typedef int8_t int_fast8_t; williamr@2: using ::uint8_t; williamr@2: typedef uint8_t uint_least8_t; williamr@2: typedef uint8_t uint_fast8_t; williamr@2: williamr@2: using ::int16_t; williamr@2: typedef int16_t int_least16_t; williamr@2: typedef int16_t int_fast16_t; williamr@2: using ::uint16_t; williamr@2: typedef uint16_t uint_least16_t; williamr@2: typedef uint16_t uint_fast16_t; williamr@2: williamr@2: using ::int32_t; williamr@2: typedef int32_t int_least32_t; williamr@2: typedef int32_t int_fast32_t; williamr@2: using ::uint32_t; williamr@2: typedef uint32_t uint_least32_t; williamr@2: typedef uint32_t uint_fast32_t; williamr@2: williamr@2: # ifndef BOOST_NO_INT64_T williamr@2: williamr@2: using ::int64_t; williamr@2: typedef int64_t int_least64_t; williamr@2: typedef int64_t int_fast64_t; williamr@2: using ::uint64_t; williamr@2: typedef uint64_t uint_least64_t; williamr@2: typedef uint64_t uint_fast64_t; williamr@2: williamr@2: typedef int64_t intmax_t; williamr@2: typedef uint64_t uintmax_t; williamr@2: williamr@2: # else williamr@2: williamr@2: typedef int32_t intmax_t; williamr@2: typedef uint32_t uintmax_t; williamr@2: williamr@2: # endif williamr@2: williamr@2: } // namespace boost williamr@2: williamr@2: #else // BOOST_HAS_STDINT_H williamr@2: williamr@2: # include // implementation artifact; not part of interface williamr@2: # include // needed for limits macros williamr@2: williamr@2: williamr@2: namespace boost williamr@2: { williamr@2: williamr@2: // These are fairly safe guesses for some 16-bit, and most 32-bit and 64-bit williamr@2: // platforms. For other systems, they will have to be hand tailored. williamr@2: // williamr@2: // Because the fast types are assumed to be the same as the undecorated types, williamr@2: // it may be possible to hand tailor a more efficient implementation. Such williamr@2: // an optimization may be illusionary; on the Intel x86-family 386 on, for williamr@2: // example, byte arithmetic and load/stores are as fast as "int" sized ones. williamr@2: williamr@2: // 8-bit types ------------------------------------------------------------// williamr@2: williamr@2: # if UCHAR_MAX == 0xff williamr@2: typedef signed char int8_t; williamr@2: typedef signed char int_least8_t; williamr@2: typedef signed char int_fast8_t; williamr@2: typedef unsigned char uint8_t; williamr@2: typedef unsigned char uint_least8_t; williamr@2: typedef unsigned char uint_fast8_t; williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: williamr@2: // 16-bit types -----------------------------------------------------------// williamr@2: williamr@2: # if USHRT_MAX == 0xffff williamr@2: # if defined(__crayx1) williamr@2: // The Cray X1 has a 16-bit short, however it is not recommend williamr@2: // for use in performance critical code. williamr@2: typedef short int16_t; williamr@2: typedef short int_least16_t; williamr@2: typedef int int_fast16_t; williamr@2: typedef unsigned short uint16_t; williamr@2: typedef unsigned short uint_least16_t; williamr@2: typedef unsigned int uint_fast16_t; williamr@2: # else williamr@2: typedef short int16_t; williamr@2: typedef short int_least16_t; williamr@2: typedef short int_fast16_t; williamr@2: typedef unsigned short uint16_t; williamr@2: typedef unsigned short uint_least16_t; williamr@2: typedef unsigned short uint_fast16_t; williamr@2: # endif williamr@2: # elif (USHRT_MAX == 0xffffffff) && defined(CRAY) williamr@2: // no 16-bit types on Cray: williamr@2: typedef short int_least16_t; williamr@2: typedef short int_fast16_t; williamr@2: typedef unsigned short uint_least16_t; williamr@2: typedef unsigned short uint_fast16_t; williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: williamr@2: // 32-bit types -----------------------------------------------------------// williamr@2: williamr@2: # if ULONG_MAX == 0xffffffff williamr@2: typedef long int32_t; williamr@2: typedef long int_least32_t; williamr@2: typedef long int_fast32_t; williamr@2: typedef unsigned long uint32_t; williamr@2: typedef unsigned long uint_least32_t; williamr@2: typedef unsigned long uint_fast32_t; williamr@2: # elif UINT_MAX == 0xffffffff williamr@2: typedef int int32_t; williamr@2: typedef int int_least32_t; williamr@2: typedef int int_fast32_t; williamr@2: typedef unsigned int uint32_t; williamr@2: typedef unsigned int uint_least32_t; williamr@2: typedef unsigned int uint_fast32_t; williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: williamr@2: // 64-bit types + intmax_t and uintmax_t ----------------------------------// williamr@2: williamr@2: # if defined(BOOST_HAS_LONG_LONG) && \ williamr@2: !defined(BOOST_MSVC) && !defined(__BORLANDC__) && \ williamr@2: (!defined(__GLIBCPP__) || defined(_GLIBCPP_USE_LONG_LONG)) && \ williamr@2: (defined(ULLONG_MAX) || defined(ULONG_LONG_MAX) || defined(ULONGLONG_MAX)) williamr@2: # if defined(__hpux) williamr@2: // HP-UX's value of ULONG_LONG_MAX is unusable in preprocessor expressions williamr@2: # elif (defined(ULLONG_MAX) && ULLONG_MAX == 18446744073709551615ULL) || (defined(ULONG_LONG_MAX) && ULONG_LONG_MAX == 18446744073709551615ULL) || (defined(ULONGLONG_MAX) && ULONGLONG_MAX == 18446744073709551615ULL) williamr@2: // 2**64 - 1 williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: williamr@2: typedef ::boost::long_long_type intmax_t; williamr@2: typedef ::boost::ulong_long_type uintmax_t; williamr@2: typedef ::boost::long_long_type int64_t; williamr@2: typedef ::boost::long_long_type int_least64_t; williamr@2: typedef ::boost::long_long_type int_fast64_t; williamr@2: typedef ::boost::ulong_long_type uint64_t; williamr@2: typedef ::boost::ulong_long_type uint_least64_t; williamr@2: typedef ::boost::ulong_long_type uint_fast64_t; williamr@2: williamr@2: # elif ULONG_MAX != 0xffffffff williamr@2: williamr@2: # if ULONG_MAX == 18446744073709551615 // 2**64 - 1 williamr@2: typedef long intmax_t; williamr@2: typedef unsigned long uintmax_t; williamr@2: typedef long int64_t; williamr@2: typedef long int_least64_t; williamr@2: typedef long int_fast64_t; williamr@2: typedef unsigned long uint64_t; williamr@2: typedef unsigned long uint_least64_t; williamr@2: typedef unsigned long uint_fast64_t; williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: # elif defined(__GNUC__) && defined(BOOST_HAS_LONG_LONG) williamr@2: __extension__ typedef long long intmax_t; williamr@2: __extension__ typedef unsigned long long uintmax_t; williamr@2: __extension__ typedef long long int64_t; williamr@2: __extension__ typedef long long int_least64_t; williamr@2: __extension__ typedef long long int_fast64_t; williamr@2: __extension__ typedef unsigned long long uint64_t; williamr@2: __extension__ typedef unsigned long long uint_least64_t; williamr@2: __extension__ typedef unsigned long long uint_fast64_t; williamr@2: # elif defined(BOOST_HAS_MS_INT64) williamr@2: // williamr@2: // we have Borland/Intel/Microsoft __int64: williamr@2: // williamr@2: typedef __int64 intmax_t; williamr@2: typedef unsigned __int64 uintmax_t; williamr@2: typedef __int64 int64_t; williamr@2: typedef __int64 int_least64_t; williamr@2: typedef __int64 int_fast64_t; williamr@2: typedef unsigned __int64 uint64_t; williamr@2: typedef unsigned __int64 uint_least64_t; williamr@2: typedef unsigned __int64 uint_fast64_t; williamr@2: # else // assume no 64-bit integers williamr@2: # define BOOST_NO_INT64_T williamr@2: typedef int32_t intmax_t; williamr@2: typedef uint32_t uintmax_t; williamr@2: # endif williamr@2: williamr@2: } // namespace boost williamr@2: williamr@2: williamr@2: #endif // BOOST_HAS_STDINT_H williamr@2: williamr@2: #endif // BOOST_CSTDINT_HPP williamr@2: williamr@2: williamr@2: /**************************************************** williamr@2: williamr@2: Macro definition section: williamr@2: williamr@2: Define various INTXX_C macros only if williamr@2: __STDC_CONSTANT_MACROS is defined. williamr@2: williamr@2: Undefine the macros if __STDC_CONSTANT_MACROS is williamr@2: not defined and the macros are (cf ). williamr@2: williamr@2: Added 23rd September 2000 (John Maddock). williamr@2: Modified 11th September 2001 to be excluded when williamr@2: BOOST_HAS_STDINT_H is defined (John Maddock). williamr@2: williamr@2: ******************************************************/ williamr@2: williamr@2: #if defined(__STDC_CONSTANT_MACROS) && !defined(BOOST__STDC_CONSTANT_MACROS_DEFINED) && !defined(BOOST_HAS_STDINT_H) williamr@2: # define BOOST__STDC_CONSTANT_MACROS_DEFINED williamr@2: # if defined(BOOST_HAS_MS_INT64) williamr@2: // williamr@2: // Borland/Intel/Microsoft compilers have width specific suffixes: williamr@2: // williamr@2: # define INT8_C(value) value##i8 williamr@2: # define INT16_C(value) value##i16 williamr@2: # define INT32_C(value) value##i32 williamr@2: # define INT64_C(value) value##i64 williamr@2: # ifdef __BORLANDC__ williamr@2: // Borland bug: appending ui8 makes the type a signed char williamr@2: # define UINT8_C(value) static_cast(value##u) williamr@2: # else williamr@2: # define UINT8_C(value) value##ui8 williamr@2: # endif williamr@2: # define UINT16_C(value) value##ui16 williamr@2: # define UINT32_C(value) value##ui32 williamr@2: # define UINT64_C(value) value##ui64 williamr@2: # define INTMAX_C(value) value##i64 williamr@2: # define UINTMAX_C(value) value##ui64 williamr@2: williamr@2: # else williamr@2: // do it the old fashioned way: williamr@2: williamr@2: // 8-bit types ------------------------------------------------------------// williamr@2: williamr@2: # if UCHAR_MAX == 0xff williamr@2: # define INT8_C(value) static_cast(value) williamr@2: # define UINT8_C(value) static_cast(value##u) williamr@2: # endif williamr@2: williamr@2: // 16-bit types -----------------------------------------------------------// williamr@2: williamr@2: # if USHRT_MAX == 0xffff williamr@2: # define INT16_C(value) static_cast(value) williamr@2: # define UINT16_C(value) static_cast(value##u) williamr@2: # endif williamr@2: williamr@2: // 32-bit types -----------------------------------------------------------// williamr@2: williamr@2: # if UINT_MAX == 0xffffffff williamr@2: # define INT32_C(value) value williamr@2: # define UINT32_C(value) value##u williamr@2: # elif ULONG_MAX == 0xffffffff williamr@2: # define INT32_C(value) value##L williamr@2: # define UINT32_C(value) value##uL williamr@2: # endif williamr@2: williamr@2: // 64-bit types + intmax_t and uintmax_t ----------------------------------// williamr@2: williamr@2: # if defined(BOOST_HAS_LONG_LONG) && \ williamr@2: (defined(ULLONG_MAX) || defined(ULONG_LONG_MAX) || defined(ULONGLONG_MAX)) williamr@2: williamr@2: # if defined(__hpux) williamr@2: // HP-UX's value of ULONG_LONG_MAX is unusable in preprocessor expressions williamr@2: # elif (defined(ULLONG_MAX) && ULLONG_MAX == 18446744073709551615U) || \ williamr@2: (defined(ULONG_LONG_MAX) && ULONG_LONG_MAX == 18446744073709551615U) || \ williamr@2: (defined(ULONGLONG_MAX) && ULONGLONG_MAX == 18446744073709551615U) williamr@2: williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: # define INT64_C(value) value##LL williamr@2: # define UINT64_C(value) value##uLL williamr@2: # elif ULONG_MAX != 0xffffffff williamr@2: williamr@2: # if ULONG_MAX == 18446744073709551615 // 2**64 - 1 williamr@2: # define INT64_C(value) value##L williamr@2: # define UINT64_C(value) value##uL williamr@2: # else williamr@2: # error defaults not correct; you must hand modify boost/cstdint.hpp williamr@2: # endif williamr@2: # endif williamr@2: williamr@2: # ifdef BOOST_NO_INT64_T williamr@2: # define INTMAX_C(value) INT32_C(value) williamr@2: # define UINTMAX_C(value) UINT32_C(value) williamr@2: # else williamr@2: # define INTMAX_C(value) INT64_C(value) williamr@2: # define UINTMAX_C(value) UINT64_C(value) williamr@2: # endif williamr@2: williamr@2: # endif // Borland/Microsoft specific width suffixes williamr@2: williamr@2: williamr@2: #elif defined(BOOST__STDC_CONSTANT_MACROS_DEFINED) && !defined(__STDC_CONSTANT_MACROS) && !defined(BOOST_HAS_STDINT_H) williamr@2: // williamr@2: // undef all the macros: williamr@2: // williamr@2: # undef INT8_C williamr@2: # undef INT16_C williamr@2: # undef INT32_C williamr@2: # undef INT64_C williamr@2: # undef UINT8_C williamr@2: # undef UINT16_C williamr@2: # undef UINT32_C williamr@2: # undef UINT64_C williamr@2: # undef INTMAX_C williamr@2: # undef UINTMAX_C williamr@2: williamr@2: #endif // __STDC_CONSTANT_MACROS_DEFINED etc. williamr@2: williamr@2: williamr@2: williamr@2: