diff options
Diffstat (limited to '3rdParty/Boost/src/boost/cstdint.hpp')
| -rw-r--r-- | 3rdParty/Boost/src/boost/cstdint.hpp | 219 | 
1 files changed, 128 insertions, 91 deletions
| diff --git a/3rdParty/Boost/src/boost/cstdint.hpp b/3rdParty/Boost/src/boost/cstdint.hpp index ea84b65..98faeae 100644 --- a/3rdParty/Boost/src/boost/cstdint.hpp +++ b/3rdParty/Boost/src/boost/cstdint.hpp @@ -1,7 +1,7 @@  //  boost cstdint.hpp header file  ------------------------------------------// -//  (C) Copyright Beman Dawes 1999.  -//  (C) Copyright Jens Mauer 2001   -//  (C) Copyright John Maddock 2001  +//  (C) Copyright Beman Dawes 1999. +//  (C) Copyright Jens Mauer 2001 +//  (C) Copyright John Maddock 2001  //  Distributed under the Boost  //  Software License, Version 1.0. (See accompanying file @@ -25,7 +25,7 @@  // -// Since we always define the INT#_C macros as per C++0x,  +// Since we always define the INT#_C macros as per C++0x,  // define __STDC_CONSTANT_MACROS so that <stdint.h> does the right -// thing if possible, and so that the user knows that the macros  +// thing if possible, and so that the user knows that the macros  // are actually defined as per C99.  // @@ -42,5 +42,8 @@  // See https://svn.boost.org/trac/boost/ticket/3548 and http://sources.redhat.com/bugzilla/show_bug.cgi?id=10990  // -#if defined(BOOST_HAS_STDINT_H) && (!defined(__GLIBC__) || defined(__GLIBC_HAVE_LONG_LONG)) +#if defined(BOOST_HAS_STDINT_H)					\ +  && (!defined(__GLIBC__)					\ +      || defined(__GLIBC_HAVE_LONG_LONG)			\ +      || (defined(__GLIBC__) && ((__GLIBC__ > 2) || ((__GLIBC__ == 2) && (__GLIBC_MINOR__ >= 17)))))  // The following #include is an implementation artifact; not part of interface. @@ -51,5 +54,5 @@        // this is triggered with GCC, because it defines __cplusplus < 199707L  #     define BOOST_NO_INT64_T -#   endif  +#   endif  # elif defined(__FreeBSD__) || defined(__IBMCPP__) || defined(_AIX)  #   include <inttypes.h> @@ -101,38 +104,38 @@ namespace boost  { -  using ::int8_t;              -  using ::int_least8_t;        -  using ::int_fast8_t;         -  using ::uint8_t;             -  using ::uint_least8_t;       -  using ::uint_fast8_t;        -                      -  using ::int16_t;             -  using ::int_least16_t;       -  using ::int_fast16_t;        -  using ::uint16_t;            -  using ::uint_least16_t;      -  using ::uint_fast16_t;       -                      -  using ::int32_t;             -  using ::int_least32_t;       -  using ::int_fast32_t;        -  using ::uint32_t;            -  using ::uint_least32_t;      -  using ::uint_fast32_t;       -                      +  using ::int8_t; +  using ::int_least8_t; +  using ::int_fast8_t; +  using ::uint8_t; +  using ::uint_least8_t; +  using ::uint_fast8_t; + +  using ::int16_t; +  using ::int_least16_t; +  using ::int_fast16_t; +  using ::uint16_t; +  using ::uint_least16_t; +  using ::uint_fast16_t; + +  using ::int32_t; +  using ::int_least32_t; +  using ::int_fast32_t; +  using ::uint32_t; +  using ::uint_least32_t; +  using ::uint_fast32_t; +  # ifndef BOOST_NO_INT64_T -  using ::int64_t;             -  using ::int_least64_t;       -  using ::int_fast64_t;        -  using ::uint64_t;            -  using ::uint_least64_t;      -  using ::uint_fast64_t;       -                      +  using ::int64_t; +  using ::int_least64_t; +  using ::int_fast64_t; +  using ::uint64_t; +  using ::uint_least64_t; +  using ::uint_fast64_t; +  # endif -  using ::intmax_t;       -  using ::uintmax_t;      +  using ::intmax_t; +  using ::uintmax_t;  } // namespace boost @@ -144,33 +147,33 @@ namespace boost  namespace boost { -  using ::int8_t;              -  typedef int8_t int_least8_t;        -  typedef int8_t int_fast8_t;         -  using ::uint8_t;             -  typedef uint8_t uint_least8_t;       -  typedef uint8_t uint_fast8_t;        -                      -  using ::int16_t;             -  typedef int16_t int_least16_t;       -  typedef int16_t int_fast16_t;        -  using ::uint16_t;            -  typedef uint16_t uint_least16_t;      -  typedef uint16_t uint_fast16_t;       -                      -  using ::int32_t;             -  typedef int32_t int_least32_t;       -  typedef int32_t int_fast32_t;        -  using ::uint32_t;            -  typedef uint32_t uint_least32_t;      -  typedef uint32_t uint_fast32_t;       -          -# ifndef BOOST_NO_INT64_T           - -  using ::int64_t;             -  typedef int64_t int_least64_t;       -  typedef int64_t int_fast64_t;        -  using ::uint64_t;            -  typedef uint64_t uint_least64_t;      -  typedef uint64_t uint_fast64_t;       +  using ::int8_t; +  typedef int8_t int_least8_t; +  typedef int8_t int_fast8_t; +  using ::uint8_t; +  typedef uint8_t uint_least8_t; +  typedef uint8_t uint_fast8_t; + +  using ::int16_t; +  typedef int16_t int_least16_t; +  typedef int16_t int_fast16_t; +  using ::uint16_t; +  typedef uint16_t uint_least16_t; +  typedef uint16_t uint_fast16_t; + +  using ::int32_t; +  typedef int32_t int_least32_t; +  typedef int32_t int_fast32_t; +  using ::uint32_t; +  typedef uint32_t uint_least32_t; +  typedef uint32_t uint_fast32_t; + +# ifndef BOOST_NO_INT64_T + +  using ::int64_t; +  typedef int64_t int_least64_t; +  typedef int64_t int_fast64_t; +  using ::uint64_t; +  typedef uint64_t uint_least64_t; +  typedef uint64_t uint_fast64_t;    typedef int64_t intmax_t; @@ -236,13 +239,13 @@ namespace boost       typedef unsigned short  uint_fast16_t;  #  endif -# elif (USHRT_MAX == 0xffffffff) && defined(__MTA__)  -      // On MTA / XMT short is 32 bits unless the -short16 compiler flag is specified  -      // MTA / XMT does support the following non-standard integer types  -      typedef __short16           int16_t;  -      typedef __short16           int_least16_t;  -      typedef __short16           int_fast16_t;  -      typedef unsigned __short16  uint16_t;  -      typedef unsigned __short16  uint_least16_t;  -      typedef unsigned __short16  uint_fast16_t;  +# elif (USHRT_MAX == 0xffffffff) && defined(__MTA__) +      // On MTA / XMT short is 32 bits unless the -short16 compiler flag is specified +      // MTA / XMT does support the following non-standard integer types +      typedef __short16           int16_t; +      typedef __short16           int_least16_t; +      typedef __short16           int_fast16_t; +      typedef unsigned __short16  uint16_t; +      typedef unsigned __short16  uint_least16_t; +      typedef unsigned __short16  uint_fast16_t;  # elif (USHRT_MAX == 0xffffffff) && defined(CRAY)       // no 16-bit types on Cray: @@ -278,12 +281,12 @@ namespace boost       typedef unsigned long   uint_least32_t;       typedef unsigned long   uint_fast32_t; -# elif (UINT_MAX == 0xffffffffffffffff) && defined(__MTA__)  -      // Integers are 64 bits on the MTA / XMT  -      typedef __int32           int32_t;  -      typedef __int32           int_least32_t;  -      typedef __int32           int_fast32_t;  -      typedef unsigned __int32  uint32_t;  -      typedef unsigned __int32  uint_least32_t;  -      typedef unsigned __int32  uint_fast32_t;  +# elif (UINT_MAX == 0xffffffffffffffff) && defined(__MTA__) +      // Integers are 64 bits on the MTA / XMT +      typedef __int32           int32_t; +      typedef __int32           int_least32_t; +      typedef __int32           int_fast32_t; +      typedef unsigned __int32  uint32_t; +      typedef unsigned __int32  uint_least32_t; +      typedef unsigned __int32  uint_fast32_t;  # else  #    error defaults not correct; you must hand modify boost/cstdint.hpp @@ -359,4 +362,38 @@ namespace boost  #endif // BOOST_HAS_STDINT_H +// intptr_t/uintptr_t are defined separately because they are optional and not universally available +#if defined(BOOST_WINDOWS) && !defined(_WIN32_WCE) && !defined(BOOST_HAS_STDINT_H) +// Older MSVC don't have stdint.h and have intptr_t/uintptr_t defined in stddef.h +#include <stddef.h> +#endif + +// PGI seems to not support intptr_t/uintptr_t properly. BOOST_HAS_STDINT_H is not defined for this compiler by Boost.Config. +#if !defined(__PGIC__) + +#if (defined(BOOST_WINDOWS) && !defined(_WIN32_WCE)) \ +    || (defined(_XOPEN_UNIX) && (_XOPEN_UNIX+0 > 0) && !defined(__UCLIBC__)) \ +    || defined(__CYGWIN__) \ +    || defined(macintosh) || defined(__APPLE__) || defined(__APPLE_CC__) \ +    || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__DragonFly__) + +namespace boost { +    using ::intptr_t; +    using ::uintptr_t; +} +#define BOOST_HAS_INTPTR_T + +// Clang pretends to be GCC, so it'll match this condition +#elif defined(__GNUC__) && defined(__INTPTR_TYPE__) && defined(__UINTPTR_TYPE__) + +namespace boost { +    typedef __INTPTR_TYPE__ intptr_t; +    typedef __UINTPTR_TYPE__ uintptr_t; +} +#define BOOST_HAS_INTPTR_T + +#endif + +#endif // !defined(__PGIC__) +  #endif // BOOST_CSTDINT_HPP @@ -377,13 +414,13 @@ INT#_C macros if they're not already defined (John Maddock).     (!defined(INT8_C) || !defined(INT16_C) || !defined(INT32_C) || !defined(INT64_C))  // -// For the following code we get several warnings along the lines of:  -//  -// boost/cstdint.hpp:428:35: error: use of C99 long long integer constant  -//  -// So we declare this a system header to suppress these warnings.  +// For the following code we get several warnings along the lines of: +// +// boost/cstdint.hpp:428:35: error: use of C99 long long integer constant  // -#if defined(__GNUC__) && (__GNUC__ >= 4)  -#pragma GCC system_header  -#endif  +// So we declare this a system header to suppress these warnings. +// +#if defined(__GNUC__) && (__GNUC__ >= 4) +#pragma GCC system_header +#endif  #include <limits.h> | 
 Swift
 Swift