Jeff Thompson | a28eed8 | 2013-08-22 16:21:10 -0700 | [diff] [blame^] | 1 | // boost cstdint.hpp header file ------------------------------------------// |
| 2 | |
| 3 | // (C) Copyright Beman Dawes 1999. |
| 4 | // (C) Copyright Jens Mauer 2001 |
| 5 | // (C) Copyright John Maddock 2001 |
| 6 | // Distributed under the Boost |
| 7 | // Software License, Version 1.0. (See accompanying file |
| 8 | // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) |
| 9 | |
| 10 | // See http://www.boost.org/libs/integer for documentation. |
| 11 | |
| 12 | // Revision History |
| 13 | // 31 Oct 01 use BOOST_HAS_LONG_LONG to check for "long long" (Jens M.) |
| 14 | // 16 Apr 01 check LONGLONG_MAX when looking for "long long" (Jens Maurer) |
| 15 | // 23 Jan 01 prefer "long" over "int" for int32_t and intmax_t (Jens Maurer) |
| 16 | // 12 Nov 00 Merged <ndnboost/stdint.h> (Jens Maurer) |
| 17 | // 23 Sep 00 Added INTXX_C macro support (John Maddock). |
| 18 | // 22 Sep 00 Better 64-bit support (John Maddock) |
| 19 | // 29 Jun 00 Reimplement to avoid including stdint.h within namespace ndnboost |
| 20 | // 8 Aug 99 Initial version (Beman Dawes) |
| 21 | |
| 22 | |
| 23 | #ifndef BOOST_CSTDINT_HPP |
| 24 | #define BOOST_CSTDINT_HPP |
| 25 | |
| 26 | // |
| 27 | // Since we always define the INT#_C macros as per C++0x, |
| 28 | // define __STDC_CONSTANT_MACROS so that <stdint.h> does the right |
| 29 | // thing if possible, and so that the user knows that the macros |
| 30 | // are actually defined as per C99. |
| 31 | // |
| 32 | #ifndef __STDC_CONSTANT_MACROS |
| 33 | # define __STDC_CONSTANT_MACROS |
| 34 | #endif |
| 35 | |
| 36 | #include <ndnboost/config.hpp> |
| 37 | |
| 38 | // |
| 39 | // Note that GLIBC is a bit inconsistent about whether int64_t is defined or not |
| 40 | // depending upon what headers happen to have been included first... |
| 41 | // so we disable use of stdint.h when GLIBC does not define __GLIBC_HAVE_LONG_LONG. |
| 42 | // See https://svn.boost.org/trac/boost/ticket/3548 and http://sources.redhat.com/bugzilla/show_bug.cgi?id=10990 |
| 43 | // |
| 44 | #if defined(BOOST_HAS_STDINT_H) && (!defined(__GLIBC__) || defined(__GLIBC_HAVE_LONG_LONG)) |
| 45 | |
| 46 | // The following #include is an implementation artifact; not part of interface. |
| 47 | # ifdef __hpux |
| 48 | // HP-UX has a vaguely nice <stdint.h> in a non-standard location |
| 49 | # include <inttypes.h> |
| 50 | # ifdef __STDC_32_MODE__ |
| 51 | // this is triggered with GCC, because it defines __cplusplus < 199707L |
| 52 | # define BOOST_NO_INT64_T |
| 53 | # endif |
| 54 | # elif defined(__FreeBSD__) || defined(__IBMCPP__) || defined(_AIX) |
| 55 | # include <inttypes.h> |
| 56 | # else |
| 57 | # include <stdint.h> |
| 58 | |
| 59 | // There is a bug in Cygwin two _C macros |
| 60 | # if defined(__STDC_CONSTANT_MACROS) && defined(__CYGWIN__) |
| 61 | # undef INTMAX_C |
| 62 | # undef UINTMAX_C |
| 63 | # define INTMAX_C(c) c##LL |
| 64 | # define UINTMAX_C(c) c##ULL |
| 65 | # endif |
| 66 | |
| 67 | # endif |
| 68 | |
| 69 | #ifdef __QNX__ |
| 70 | |
| 71 | // QNX (Dinkumware stdlib) defines these as non-standard names. |
| 72 | // Reflect to the standard names. |
| 73 | |
| 74 | typedef ::intleast8_t int_least8_t; |
| 75 | typedef ::intfast8_t int_fast8_t; |
| 76 | typedef ::uintleast8_t uint_least8_t; |
| 77 | typedef ::uintfast8_t uint_fast8_t; |
| 78 | |
| 79 | typedef ::intleast16_t int_least16_t; |
| 80 | typedef ::intfast16_t int_fast16_t; |
| 81 | typedef ::uintleast16_t uint_least16_t; |
| 82 | typedef ::uintfast16_t uint_fast16_t; |
| 83 | |
| 84 | typedef ::intleast32_t int_least32_t; |
| 85 | typedef ::intfast32_t int_fast32_t; |
| 86 | typedef ::uintleast32_t uint_least32_t; |
| 87 | typedef ::uintfast32_t uint_fast32_t; |
| 88 | |
| 89 | # ifndef BOOST_NO_INT64_T |
| 90 | |
| 91 | typedef ::intleast64_t int_least64_t; |
| 92 | typedef ::intfast64_t int_fast64_t; |
| 93 | typedef ::uintleast64_t uint_least64_t; |
| 94 | typedef ::uintfast64_t uint_fast64_t; |
| 95 | |
| 96 | # endif |
| 97 | |
| 98 | #endif |
| 99 | |
| 100 | namespace ndnboost |
| 101 | { |
| 102 | |
| 103 | using ::int8_t; |
| 104 | using ::int_least8_t; |
| 105 | using ::int_fast8_t; |
| 106 | using ::uint8_t; |
| 107 | using ::uint_least8_t; |
| 108 | using ::uint_fast8_t; |
| 109 | |
| 110 | using ::int16_t; |
| 111 | using ::int_least16_t; |
| 112 | using ::int_fast16_t; |
| 113 | using ::uint16_t; |
| 114 | using ::uint_least16_t; |
| 115 | using ::uint_fast16_t; |
| 116 | |
| 117 | using ::int32_t; |
| 118 | using ::int_least32_t; |
| 119 | using ::int_fast32_t; |
| 120 | using ::uint32_t; |
| 121 | using ::uint_least32_t; |
| 122 | using ::uint_fast32_t; |
| 123 | |
| 124 | # ifndef BOOST_NO_INT64_T |
| 125 | |
| 126 | using ::int64_t; |
| 127 | using ::int_least64_t; |
| 128 | using ::int_fast64_t; |
| 129 | using ::uint64_t; |
| 130 | using ::uint_least64_t; |
| 131 | using ::uint_fast64_t; |
| 132 | |
| 133 | # endif |
| 134 | |
| 135 | using ::intmax_t; |
| 136 | using ::uintmax_t; |
| 137 | |
| 138 | } // namespace ndnboost |
| 139 | |
| 140 | #elif defined(__FreeBSD__) && (__FreeBSD__ <= 4) || defined(__osf__) || defined(__VMS) |
| 141 | // FreeBSD and Tru64 have an <inttypes.h> that contains much of what we need. |
| 142 | # include <inttypes.h> |
| 143 | |
| 144 | namespace ndnboost { |
| 145 | |
| 146 | using ::int8_t; |
| 147 | typedef int8_t int_least8_t; |
| 148 | typedef int8_t int_fast8_t; |
| 149 | using ::uint8_t; |
| 150 | typedef uint8_t uint_least8_t; |
| 151 | typedef uint8_t uint_fast8_t; |
| 152 | |
| 153 | using ::int16_t; |
| 154 | typedef int16_t int_least16_t; |
| 155 | typedef int16_t int_fast16_t; |
| 156 | using ::uint16_t; |
| 157 | typedef uint16_t uint_least16_t; |
| 158 | typedef uint16_t uint_fast16_t; |
| 159 | |
| 160 | using ::int32_t; |
| 161 | typedef int32_t int_least32_t; |
| 162 | typedef int32_t int_fast32_t; |
| 163 | using ::uint32_t; |
| 164 | typedef uint32_t uint_least32_t; |
| 165 | typedef uint32_t uint_fast32_t; |
| 166 | |
| 167 | # ifndef BOOST_NO_INT64_T |
| 168 | |
| 169 | using ::int64_t; |
| 170 | typedef int64_t int_least64_t; |
| 171 | typedef int64_t int_fast64_t; |
| 172 | using ::uint64_t; |
| 173 | typedef uint64_t uint_least64_t; |
| 174 | typedef uint64_t uint_fast64_t; |
| 175 | |
| 176 | typedef int64_t intmax_t; |
| 177 | typedef uint64_t uintmax_t; |
| 178 | |
| 179 | # else |
| 180 | |
| 181 | typedef int32_t intmax_t; |
| 182 | typedef uint32_t uintmax_t; |
| 183 | |
| 184 | # endif |
| 185 | |
| 186 | } // namespace ndnboost |
| 187 | |
| 188 | #else // BOOST_HAS_STDINT_H |
| 189 | |
| 190 | # include <ndnboost/limits.hpp> // implementation artifact; not part of interface |
| 191 | # include <limits.h> // needed for limits macros |
| 192 | |
| 193 | |
| 194 | namespace ndnboost |
| 195 | { |
| 196 | |
| 197 | // These are fairly safe guesses for some 16-bit, and most 32-bit and 64-bit |
| 198 | // platforms. For other systems, they will have to be hand tailored. |
| 199 | // |
| 200 | // Because the fast types are assumed to be the same as the undecorated types, |
| 201 | // it may be possible to hand tailor a more efficient implementation. Such |
| 202 | // an optimization may be illusionary; on the Intel x86-family 386 on, for |
| 203 | // example, byte arithmetic and load/stores are as fast as "int" sized ones. |
| 204 | |
| 205 | // 8-bit types ------------------------------------------------------------// |
| 206 | |
| 207 | # if UCHAR_MAX == 0xff |
| 208 | typedef signed char int8_t; |
| 209 | typedef signed char int_least8_t; |
| 210 | typedef signed char int_fast8_t; |
| 211 | typedef unsigned char uint8_t; |
| 212 | typedef unsigned char uint_least8_t; |
| 213 | typedef unsigned char uint_fast8_t; |
| 214 | # else |
| 215 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 216 | # endif |
| 217 | |
| 218 | // 16-bit types -----------------------------------------------------------// |
| 219 | |
| 220 | # if USHRT_MAX == 0xffff |
| 221 | # if defined(__crayx1) |
| 222 | // The Cray X1 has a 16-bit short, however it is not recommend |
| 223 | // for use in performance critical code. |
| 224 | typedef short int16_t; |
| 225 | typedef short int_least16_t; |
| 226 | typedef int int_fast16_t; |
| 227 | typedef unsigned short uint16_t; |
| 228 | typedef unsigned short uint_least16_t; |
| 229 | typedef unsigned int uint_fast16_t; |
| 230 | # else |
| 231 | typedef short int16_t; |
| 232 | typedef short int_least16_t; |
| 233 | typedef short int_fast16_t; |
| 234 | typedef unsigned short uint16_t; |
| 235 | typedef unsigned short uint_least16_t; |
| 236 | typedef unsigned short uint_fast16_t; |
| 237 | # endif |
| 238 | # elif (USHRT_MAX == 0xffffffff) && defined(__MTA__) |
| 239 | // On MTA / XMT short is 32 bits unless the -short16 compiler flag is specified |
| 240 | // MTA / XMT does support the following non-standard integer types |
| 241 | typedef __short16 int16_t; |
| 242 | typedef __short16 int_least16_t; |
| 243 | typedef __short16 int_fast16_t; |
| 244 | typedef unsigned __short16 uint16_t; |
| 245 | typedef unsigned __short16 uint_least16_t; |
| 246 | typedef unsigned __short16 uint_fast16_t; |
| 247 | # elif (USHRT_MAX == 0xffffffff) && defined(CRAY) |
| 248 | // no 16-bit types on Cray: |
| 249 | typedef short int_least16_t; |
| 250 | typedef short int_fast16_t; |
| 251 | typedef unsigned short uint_least16_t; |
| 252 | typedef unsigned short uint_fast16_t; |
| 253 | # else |
| 254 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 255 | # endif |
| 256 | |
| 257 | // 32-bit types -----------------------------------------------------------// |
| 258 | |
| 259 | # if UINT_MAX == 0xffffffff |
| 260 | typedef int int32_t; |
| 261 | typedef int int_least32_t; |
| 262 | typedef int int_fast32_t; |
| 263 | typedef unsigned int uint32_t; |
| 264 | typedef unsigned int uint_least32_t; |
| 265 | typedef unsigned int uint_fast32_t; |
| 266 | # elif (USHRT_MAX == 0xffffffff) |
| 267 | typedef short int32_t; |
| 268 | typedef short int_least32_t; |
| 269 | typedef short int_fast32_t; |
| 270 | typedef unsigned short uint32_t; |
| 271 | typedef unsigned short uint_least32_t; |
| 272 | typedef unsigned short uint_fast32_t; |
| 273 | # elif ULONG_MAX == 0xffffffff |
| 274 | typedef long int32_t; |
| 275 | typedef long int_least32_t; |
| 276 | typedef long int_fast32_t; |
| 277 | typedef unsigned long uint32_t; |
| 278 | typedef unsigned long uint_least32_t; |
| 279 | typedef unsigned long uint_fast32_t; |
| 280 | # elif (UINT_MAX == 0xffffffffffffffff) && defined(__MTA__) |
| 281 | // Integers are 64 bits on the MTA / XMT |
| 282 | typedef __int32 int32_t; |
| 283 | typedef __int32 int_least32_t; |
| 284 | typedef __int32 int_fast32_t; |
| 285 | typedef unsigned __int32 uint32_t; |
| 286 | typedef unsigned __int32 uint_least32_t; |
| 287 | typedef unsigned __int32 uint_fast32_t; |
| 288 | # else |
| 289 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 290 | # endif |
| 291 | |
| 292 | // 64-bit types + intmax_t and uintmax_t ----------------------------------// |
| 293 | |
| 294 | # if defined(BOOST_HAS_LONG_LONG) && \ |
| 295 | !defined(BOOST_MSVC) && !defined(__BORLANDC__) && \ |
| 296 | (!defined(__GLIBCPP__) || defined(_GLIBCPP_USE_LONG_LONG)) && \ |
| 297 | (defined(ULLONG_MAX) || defined(ULONG_LONG_MAX) || defined(ULONGLONG_MAX)) |
| 298 | # if defined(__hpux) |
| 299 | // HP-UX's value of ULONG_LONG_MAX is unusable in preprocessor expressions |
| 300 | # elif (defined(ULLONG_MAX) && ULLONG_MAX == 18446744073709551615ULL) || (defined(ULONG_LONG_MAX) && ULONG_LONG_MAX == 18446744073709551615ULL) || (defined(ULONGLONG_MAX) && ULONGLONG_MAX == 18446744073709551615ULL) |
| 301 | // 2**64 - 1 |
| 302 | # else |
| 303 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 304 | # endif |
| 305 | |
| 306 | typedef ::ndnboost::long_long_type intmax_t; |
| 307 | typedef ::ndnboost::ulong_long_type uintmax_t; |
| 308 | typedef ::ndnboost::long_long_type int64_t; |
| 309 | typedef ::ndnboost::long_long_type int_least64_t; |
| 310 | typedef ::ndnboost::long_long_type int_fast64_t; |
| 311 | typedef ::ndnboost::ulong_long_type uint64_t; |
| 312 | typedef ::ndnboost::ulong_long_type uint_least64_t; |
| 313 | typedef ::ndnboost::ulong_long_type uint_fast64_t; |
| 314 | |
| 315 | # elif ULONG_MAX != 0xffffffff |
| 316 | |
| 317 | # if ULONG_MAX == 18446744073709551615 // 2**64 - 1 |
| 318 | typedef long intmax_t; |
| 319 | typedef unsigned long uintmax_t; |
| 320 | typedef long int64_t; |
| 321 | typedef long int_least64_t; |
| 322 | typedef long int_fast64_t; |
| 323 | typedef unsigned long uint64_t; |
| 324 | typedef unsigned long uint_least64_t; |
| 325 | typedef unsigned long uint_fast64_t; |
| 326 | # else |
| 327 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 328 | # endif |
| 329 | # elif defined(__GNUC__) && defined(BOOST_HAS_LONG_LONG) |
| 330 | __extension__ typedef long long intmax_t; |
| 331 | __extension__ typedef unsigned long long uintmax_t; |
| 332 | __extension__ typedef long long int64_t; |
| 333 | __extension__ typedef long long int_least64_t; |
| 334 | __extension__ typedef long long int_fast64_t; |
| 335 | __extension__ typedef unsigned long long uint64_t; |
| 336 | __extension__ typedef unsigned long long uint_least64_t; |
| 337 | __extension__ typedef unsigned long long uint_fast64_t; |
| 338 | # elif defined(BOOST_HAS_MS_INT64) |
| 339 | // |
| 340 | // we have Borland/Intel/Microsoft __int64: |
| 341 | // |
| 342 | typedef __int64 intmax_t; |
| 343 | typedef unsigned __int64 uintmax_t; |
| 344 | typedef __int64 int64_t; |
| 345 | typedef __int64 int_least64_t; |
| 346 | typedef __int64 int_fast64_t; |
| 347 | typedef unsigned __int64 uint64_t; |
| 348 | typedef unsigned __int64 uint_least64_t; |
| 349 | typedef unsigned __int64 uint_fast64_t; |
| 350 | # else // assume no 64-bit integers |
| 351 | # define BOOST_NO_INT64_T |
| 352 | typedef int32_t intmax_t; |
| 353 | typedef uint32_t uintmax_t; |
| 354 | # endif |
| 355 | |
| 356 | } // namespace ndnboost |
| 357 | |
| 358 | |
| 359 | #endif // BOOST_HAS_STDINT_H |
| 360 | |
| 361 | #endif // BOOST_CSTDINT_HPP |
| 362 | |
| 363 | |
| 364 | /**************************************************** |
| 365 | |
| 366 | Macro definition section: |
| 367 | |
| 368 | Added 23rd September 2000 (John Maddock). |
| 369 | Modified 11th September 2001 to be excluded when |
| 370 | BOOST_HAS_STDINT_H is defined (John Maddock). |
| 371 | Modified 11th Dec 2009 to always define the |
| 372 | INT#_C macros if they're not already defined (John Maddock). |
| 373 | |
| 374 | ******************************************************/ |
| 375 | |
| 376 | #if !defined(BOOST__STDC_CONSTANT_MACROS_DEFINED) && \ |
| 377 | (!defined(INT8_C) || !defined(INT16_C) || !defined(INT32_C) || !defined(INT64_C)) |
| 378 | // |
| 379 | // For the following code we get several warnings along the lines of: |
| 380 | // |
| 381 | // boost/cstdint.hpp:428:35: error: use of C99 long long integer constant |
| 382 | // |
| 383 | // So we declare this a system header to suppress these warnings. |
| 384 | // |
| 385 | #if defined(__GNUC__) && (__GNUC__ >= 4) |
| 386 | #pragma GCC system_header |
| 387 | #endif |
| 388 | |
| 389 | #include <limits.h> |
| 390 | # define BOOST__STDC_CONSTANT_MACROS_DEFINED |
| 391 | # if defined(BOOST_HAS_MS_INT64) |
| 392 | // |
| 393 | // Borland/Intel/Microsoft compilers have width specific suffixes: |
| 394 | // |
| 395 | #ifndef INT8_C |
| 396 | # define INT8_C(value) value##i8 |
| 397 | #endif |
| 398 | #ifndef INT16_C |
| 399 | # define INT16_C(value) value##i16 |
| 400 | #endif |
| 401 | #ifndef INT32_C |
| 402 | # define INT32_C(value) value##i32 |
| 403 | #endif |
| 404 | #ifndef INT64_C |
| 405 | # define INT64_C(value) value##i64 |
| 406 | #endif |
| 407 | # ifdef __BORLANDC__ |
| 408 | // Borland bug: appending ui8 makes the type a signed char |
| 409 | # define UINT8_C(value) static_cast<unsigned char>(value##u) |
| 410 | # else |
| 411 | # define UINT8_C(value) value##ui8 |
| 412 | # endif |
| 413 | #ifndef UINT16_C |
| 414 | # define UINT16_C(value) value##ui16 |
| 415 | #endif |
| 416 | #ifndef UINT32_C |
| 417 | # define UINT32_C(value) value##ui32 |
| 418 | #endif |
| 419 | #ifndef UINT64_C |
| 420 | # define UINT64_C(value) value##ui64 |
| 421 | #endif |
| 422 | #ifndef INTMAX_C |
| 423 | # define INTMAX_C(value) value##i64 |
| 424 | # define UINTMAX_C(value) value##ui64 |
| 425 | #endif |
| 426 | |
| 427 | # else |
| 428 | // do it the old fashioned way: |
| 429 | |
| 430 | // 8-bit types ------------------------------------------------------------// |
| 431 | |
| 432 | # if (UCHAR_MAX == 0xff) && !defined(INT8_C) |
| 433 | # define INT8_C(value) static_cast<ndnboost::int8_t>(value) |
| 434 | # define UINT8_C(value) static_cast<ndnboost::uint8_t>(value##u) |
| 435 | # endif |
| 436 | |
| 437 | // 16-bit types -----------------------------------------------------------// |
| 438 | |
| 439 | # if (USHRT_MAX == 0xffff) && !defined(INT16_C) |
| 440 | # define INT16_C(value) static_cast<ndnboost::int16_t>(value) |
| 441 | # define UINT16_C(value) static_cast<ndnboost::uint16_t>(value##u) |
| 442 | # endif |
| 443 | |
| 444 | // 32-bit types -----------------------------------------------------------// |
| 445 | #ifndef INT32_C |
| 446 | # if (UINT_MAX == 0xffffffff) |
| 447 | # define INT32_C(value) value |
| 448 | # define UINT32_C(value) value##u |
| 449 | # elif ULONG_MAX == 0xffffffff |
| 450 | # define INT32_C(value) value##L |
| 451 | # define UINT32_C(value) value##uL |
| 452 | # endif |
| 453 | #endif |
| 454 | |
| 455 | // 64-bit types + intmax_t and uintmax_t ----------------------------------// |
| 456 | #ifndef INT64_C |
| 457 | # if defined(BOOST_HAS_LONG_LONG) && \ |
| 458 | (defined(ULLONG_MAX) || defined(ULONG_LONG_MAX) || defined(ULONGLONG_MAX) || defined(_LLONG_MAX)) |
| 459 | |
| 460 | # if defined(__hpux) |
| 461 | // HP-UX's value of ULONG_LONG_MAX is unusable in preprocessor expressions |
| 462 | # define INT64_C(value) value##LL |
| 463 | # define UINT64_C(value) value##uLL |
| 464 | # elif (defined(ULLONG_MAX) && ULLONG_MAX == 18446744073709551615ULL) || \ |
| 465 | (defined(ULONG_LONG_MAX) && ULONG_LONG_MAX == 18446744073709551615ULL) || \ |
| 466 | (defined(ULONGLONG_MAX) && ULONGLONG_MAX == 18446744073709551615ULL) || \ |
| 467 | (defined(_LLONG_MAX) && _LLONG_MAX == 18446744073709551615ULL) |
| 468 | |
| 469 | # define INT64_C(value) value##LL |
| 470 | # define UINT64_C(value) value##uLL |
| 471 | # else |
| 472 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 473 | # endif |
| 474 | # elif ULONG_MAX != 0xffffffff |
| 475 | |
| 476 | # if ULONG_MAX == 18446744073709551615U // 2**64 - 1 |
| 477 | # define INT64_C(value) value##L |
| 478 | # define UINT64_C(value) value##uL |
| 479 | # else |
| 480 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 481 | # endif |
| 482 | # elif defined(BOOST_HAS_LONG_LONG) |
| 483 | // Usual macros not defined, work things out for ourselves: |
| 484 | # if(~0uLL == 18446744073709551615ULL) |
| 485 | # define INT64_C(value) value##LL |
| 486 | # define UINT64_C(value) value##uLL |
| 487 | # else |
| 488 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 489 | # endif |
| 490 | # else |
| 491 | # error defaults not correct; you must hand modify boost/cstdint.hpp |
| 492 | # endif |
| 493 | |
| 494 | # ifdef BOOST_NO_INT64_T |
| 495 | # define INTMAX_C(value) INT32_C(value) |
| 496 | # define UINTMAX_C(value) UINT32_C(value) |
| 497 | # else |
| 498 | # define INTMAX_C(value) INT64_C(value) |
| 499 | # define UINTMAX_C(value) UINT64_C(value) |
| 500 | # endif |
| 501 | #endif |
| 502 | # endif // Borland/Microsoft specific width suffixes |
| 503 | |
| 504 | #endif // INT#_C macros. |
| 505 | |
| 506 | |
| 507 | |
| 508 | |