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 <boost/stdint.h> (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 <boost/config.hpp>
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 <stdint.h> in a non-standard location
williamr@2: #   include <inttypes.h>
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 <inttypes.h>
williamr@2: # else
williamr@2: #   include <stdint.h>
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 <inttypes.h> that contains much of what we need.
williamr@2: # include <inttypes.h>
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 <boost/limits.hpp> // implementation artifact; not part of interface
williamr@2: # include <limits.h>         // 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 <cassert>).
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<unsigned char>(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<boost::int8_t>(value)
williamr@2: #   define UINT8_C(value) static_cast<boost::uint8_t>(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<boost::int16_t>(value)
williamr@2: #   define UINT16_C(value) static_cast<boost::uint16_t>(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: