]> git.donarmstrong.com Git - rsem.git/blob - boost/cstdint.hpp
Deleted a ';' at the end of RSEM v1.2.15 updates
[rsem.git] / boost / cstdint.hpp
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 <boost/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 boost
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 <boost/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)                                 \
45   && (!defined(__GLIBC__)                                       \
46       || defined(__GLIBC_HAVE_LONG_LONG)                        \
47       || (defined(__GLIBC__) && ((__GLIBC__ > 2) || ((__GLIBC__ == 2) && (__GLIBC_MINOR__ >= 17)))))
48
49 // The following #include is an implementation artifact; not part of interface.
50 # ifdef __hpux
51 // HP-UX has a vaguely nice <stdint.h> in a non-standard location
52 #   include <inttypes.h>
53 #   ifdef __STDC_32_MODE__
54       // this is triggered with GCC, because it defines __cplusplus < 199707L
55 #     define BOOST_NO_INT64_T
56 #   endif
57 # elif defined(__FreeBSD__) || defined(__IBMCPP__) || defined(_AIX)
58 #   include <inttypes.h>
59 # else
60 #   include <stdint.h>
61
62 // There is a bug in Cygwin two _C macros
63 #   if defined(__STDC_CONSTANT_MACROS) && defined(__CYGWIN__)
64 #     undef INTMAX_C
65 #     undef UINTMAX_C
66 #     define INTMAX_C(c) c##LL
67 #     define UINTMAX_C(c) c##ULL
68 #   endif
69
70 # endif
71
72 #ifdef __QNX__
73
74 // QNX (Dinkumware stdlib) defines these as non-standard names.
75 // Reflect to the standard names.
76
77 typedef ::intleast8_t int_least8_t;
78 typedef ::intfast8_t int_fast8_t;
79 typedef ::uintleast8_t uint_least8_t;
80 typedef ::uintfast8_t uint_fast8_t;
81
82 typedef ::intleast16_t int_least16_t;
83 typedef ::intfast16_t int_fast16_t;
84 typedef ::uintleast16_t uint_least16_t;
85 typedef ::uintfast16_t uint_fast16_t;
86
87 typedef ::intleast32_t int_least32_t;
88 typedef ::intfast32_t int_fast32_t;
89 typedef ::uintleast32_t uint_least32_t;
90 typedef ::uintfast32_t uint_fast32_t;
91
92 # ifndef BOOST_NO_INT64_T
93
94 typedef ::intleast64_t int_least64_t;
95 typedef ::intfast64_t int_fast64_t;
96 typedef ::uintleast64_t uint_least64_t;
97 typedef ::uintfast64_t uint_fast64_t;
98
99 # endif
100
101 #endif
102
103 namespace boost
104 {
105
106   using ::int8_t;
107   using ::int_least8_t;
108   using ::int_fast8_t;
109   using ::uint8_t;
110   using ::uint_least8_t;
111   using ::uint_fast8_t;
112
113   using ::int16_t;
114   using ::int_least16_t;
115   using ::int_fast16_t;
116   using ::uint16_t;
117   using ::uint_least16_t;
118   using ::uint_fast16_t;
119
120   using ::int32_t;
121   using ::int_least32_t;
122   using ::int_fast32_t;
123   using ::uint32_t;
124   using ::uint_least32_t;
125   using ::uint_fast32_t;
126
127 # ifndef BOOST_NO_INT64_T
128
129   using ::int64_t;
130   using ::int_least64_t;
131   using ::int_fast64_t;
132   using ::uint64_t;
133   using ::uint_least64_t;
134   using ::uint_fast64_t;
135
136 # endif
137
138   using ::intmax_t;
139   using ::uintmax_t;
140
141 } // namespace boost
142
143 #elif defined(__FreeBSD__) && (__FreeBSD__ <= 4) || defined(__osf__) || defined(__VMS)
144 // FreeBSD and Tru64 have an <inttypes.h> that contains much of what we need.
145 # include <inttypes.h>
146
147 namespace boost {
148
149   using ::int8_t;
150   typedef int8_t int_least8_t;
151   typedef int8_t int_fast8_t;
152   using ::uint8_t;
153   typedef uint8_t uint_least8_t;
154   typedef uint8_t uint_fast8_t;
155
156   using ::int16_t;
157   typedef int16_t int_least16_t;
158   typedef int16_t int_fast16_t;
159   using ::uint16_t;
160   typedef uint16_t uint_least16_t;
161   typedef uint16_t uint_fast16_t;
162
163   using ::int32_t;
164   typedef int32_t int_least32_t;
165   typedef int32_t int_fast32_t;
166   using ::uint32_t;
167   typedef uint32_t uint_least32_t;
168   typedef uint32_t uint_fast32_t;
169
170 # ifndef BOOST_NO_INT64_T
171
172   using ::int64_t;
173   typedef int64_t int_least64_t;
174   typedef int64_t int_fast64_t;
175   using ::uint64_t;
176   typedef uint64_t uint_least64_t;
177   typedef uint64_t uint_fast64_t;
178
179   typedef int64_t intmax_t;
180   typedef uint64_t uintmax_t;
181
182 # else
183
184   typedef int32_t intmax_t;
185   typedef uint32_t uintmax_t;
186
187 # endif
188
189 } // namespace boost
190
191 #else  // BOOST_HAS_STDINT_H
192
193 # include <boost/limits.hpp> // implementation artifact; not part of interface
194 # include <limits.h>         // needed for limits macros
195
196
197 namespace boost
198 {
199
200 //  These are fairly safe guesses for some 16-bit, and most 32-bit and 64-bit
201 //  platforms.  For other systems, they will have to be hand tailored.
202 //
203 //  Because the fast types are assumed to be the same as the undecorated types,
204 //  it may be possible to hand tailor a more efficient implementation.  Such
205 //  an optimization may be illusionary; on the Intel x86-family 386 on, for
206 //  example, byte arithmetic and load/stores are as fast as "int" sized ones.
207
208 //  8-bit types  ------------------------------------------------------------//
209
210 # if UCHAR_MAX == 0xff
211      typedef signed char     int8_t;
212      typedef signed char     int_least8_t;
213      typedef signed char     int_fast8_t;
214      typedef unsigned char   uint8_t;
215      typedef unsigned char   uint_least8_t;
216      typedef unsigned char   uint_fast8_t;
217 # else
218 #    error defaults not correct; you must hand modify boost/cstdint.hpp
219 # endif
220
221 //  16-bit types  -----------------------------------------------------------//
222
223 # if USHRT_MAX == 0xffff
224 #  if defined(__crayx1)
225      // The Cray X1 has a 16-bit short, however it is not recommend
226      // for use in performance critical code.
227      typedef short           int16_t;
228      typedef short           int_least16_t;
229      typedef int             int_fast16_t;
230      typedef unsigned short  uint16_t;
231      typedef unsigned short  uint_least16_t;
232      typedef unsigned int    uint_fast16_t;
233 #  else
234      typedef short           int16_t;
235      typedef short           int_least16_t;
236      typedef short           int_fast16_t;
237      typedef unsigned short  uint16_t;
238      typedef unsigned short  uint_least16_t;
239      typedef unsigned short  uint_fast16_t;
240 #  endif
241 # elif (USHRT_MAX == 0xffffffff) && defined(__MTA__)
242       // On MTA / XMT short is 32 bits unless the -short16 compiler flag is specified
243       // MTA / XMT does support the following non-standard integer types
244       typedef __short16           int16_t;
245       typedef __short16           int_least16_t;
246       typedef __short16           int_fast16_t;
247       typedef unsigned __short16  uint16_t;
248       typedef unsigned __short16  uint_least16_t;
249       typedef unsigned __short16  uint_fast16_t;
250 # elif (USHRT_MAX == 0xffffffff) && defined(CRAY)
251      // no 16-bit types on Cray:
252      typedef short           int_least16_t;
253      typedef short           int_fast16_t;
254      typedef unsigned short  uint_least16_t;
255      typedef unsigned short  uint_fast16_t;
256 # else
257 #    error defaults not correct; you must hand modify boost/cstdint.hpp
258 # endif
259
260 //  32-bit types  -----------------------------------------------------------//
261
262 # if UINT_MAX == 0xffffffff
263      typedef int             int32_t;
264      typedef int             int_least32_t;
265      typedef int             int_fast32_t;
266      typedef unsigned int    uint32_t;
267      typedef unsigned int    uint_least32_t;
268      typedef unsigned int    uint_fast32_t;
269 # elif (USHRT_MAX == 0xffffffff)
270      typedef short             int32_t;
271      typedef short             int_least32_t;
272      typedef short             int_fast32_t;
273      typedef unsigned short    uint32_t;
274      typedef unsigned short    uint_least32_t;
275      typedef unsigned short    uint_fast32_t;
276 # elif ULONG_MAX == 0xffffffff
277      typedef long            int32_t;
278      typedef long            int_least32_t;
279      typedef long            int_fast32_t;
280      typedef unsigned long   uint32_t;
281      typedef unsigned long   uint_least32_t;
282      typedef unsigned long   uint_fast32_t;
283 # elif (UINT_MAX == 0xffffffffffffffff) && defined(__MTA__)
284       // Integers are 64 bits on the MTA / XMT
285       typedef __int32           int32_t;
286       typedef __int32           int_least32_t;
287       typedef __int32           int_fast32_t;
288       typedef unsigned __int32  uint32_t;
289       typedef unsigned __int32  uint_least32_t;
290       typedef unsigned __int32  uint_fast32_t;
291 # else
292 #    error defaults not correct; you must hand modify boost/cstdint.hpp
293 # endif
294
295 //  64-bit types + intmax_t and uintmax_t  ----------------------------------//
296
297 # if defined(BOOST_HAS_LONG_LONG) && \
298    !defined(BOOST_MSVC) && !defined(__BORLANDC__) && \
299    (!defined(__GLIBCPP__) || defined(_GLIBCPP_USE_LONG_LONG)) && \
300    (defined(ULLONG_MAX) || defined(ULONG_LONG_MAX) || defined(ULONGLONG_MAX))
301 #    if defined(__hpux)
302      // HP-UX's value of ULONG_LONG_MAX is unusable in preprocessor expressions
303 #    elif (defined(ULLONG_MAX) && ULLONG_MAX == 18446744073709551615ULL) || (defined(ULONG_LONG_MAX) && ULONG_LONG_MAX == 18446744073709551615ULL) || (defined(ULONGLONG_MAX) && ULONGLONG_MAX == 18446744073709551615ULL)
304                                                                  // 2**64 - 1
305 #    else
306 #       error defaults not correct; you must hand modify boost/cstdint.hpp
307 #    endif
308
309      typedef  ::boost::long_long_type            intmax_t;
310      typedef  ::boost::ulong_long_type   uintmax_t;
311      typedef  ::boost::long_long_type            int64_t;
312      typedef  ::boost::long_long_type            int_least64_t;
313      typedef  ::boost::long_long_type            int_fast64_t;
314      typedef  ::boost::ulong_long_type   uint64_t;
315      typedef  ::boost::ulong_long_type   uint_least64_t;
316      typedef  ::boost::ulong_long_type   uint_fast64_t;
317
318 # elif ULONG_MAX != 0xffffffff
319
320 #    if ULONG_MAX == 18446744073709551615 // 2**64 - 1
321      typedef long                 intmax_t;
322      typedef unsigned long        uintmax_t;
323      typedef long                 int64_t;
324      typedef long                 int_least64_t;
325      typedef long                 int_fast64_t;
326      typedef unsigned long        uint64_t;
327      typedef unsigned long        uint_least64_t;
328      typedef unsigned long        uint_fast64_t;
329 #    else
330 #       error defaults not correct; you must hand modify boost/cstdint.hpp
331 #    endif
332 # elif defined(__GNUC__) && defined(BOOST_HAS_LONG_LONG)
333      __extension__ typedef long long            intmax_t;
334      __extension__ typedef unsigned long long   uintmax_t;
335      __extension__ typedef long long            int64_t;
336      __extension__ typedef long long            int_least64_t;
337      __extension__ typedef long long            int_fast64_t;
338      __extension__ typedef unsigned long long   uint64_t;
339      __extension__ typedef unsigned long long   uint_least64_t;
340      __extension__ typedef unsigned long long   uint_fast64_t;
341 # elif defined(BOOST_HAS_MS_INT64)
342      //
343      // we have Borland/Intel/Microsoft __int64:
344      //
345      typedef __int64             intmax_t;
346      typedef unsigned __int64    uintmax_t;
347      typedef __int64             int64_t;
348      typedef __int64             int_least64_t;
349      typedef __int64             int_fast64_t;
350      typedef unsigned __int64    uint64_t;
351      typedef unsigned __int64    uint_least64_t;
352      typedef unsigned __int64    uint_fast64_t;
353 # else // assume no 64-bit integers
354 #  define BOOST_NO_INT64_T
355      typedef int32_t              intmax_t;
356      typedef uint32_t             uintmax_t;
357 # endif
358
359 } // namespace boost
360
361
362 #endif // BOOST_HAS_STDINT_H
363
364 // intptr_t/uintptr_t are defined separately because they are optional and not universally available
365 #if defined(BOOST_WINDOWS) && !defined(_WIN32_WCE) && !defined(BOOST_HAS_STDINT_H)
366 // Older MSVC don't have stdint.h and have intptr_t/uintptr_t defined in stddef.h
367 #include <stddef.h>
368 #endif
369
370 // PGI seems to not support intptr_t/uintptr_t properly. BOOST_HAS_STDINT_H is not defined for this compiler by Boost.Config.
371 #if !defined(__PGIC__)
372
373 #if (defined(BOOST_WINDOWS) && !defined(_WIN32_WCE)) \
374     || (defined(_XOPEN_UNIX) && (_XOPEN_UNIX+0 > 0) && !defined(__UCLIBC__)) \
375     || defined(__CYGWIN__) \
376     || defined(macintosh) || defined(__APPLE__) || defined(__APPLE_CC__) \
377     || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__DragonFly__)
378
379 namespace boost {
380     using ::intptr_t;
381     using ::uintptr_t;
382 }
383 #define BOOST_HAS_INTPTR_T
384
385 // Clang pretends to be GCC, so it'll match this condition
386 #elif defined(__GNUC__) && defined(__INTPTR_TYPE__) && defined(__UINTPTR_TYPE__)
387
388 namespace boost {
389     typedef __INTPTR_TYPE__ intptr_t;
390     typedef __UINTPTR_TYPE__ uintptr_t;
391 }
392 #define BOOST_HAS_INTPTR_T
393
394 #endif
395
396 #endif // !defined(__PGIC__)
397
398 #endif // BOOST_CSTDINT_HPP
399
400
401 /****************************************************
402
403 Macro definition section:
404
405 Added 23rd September 2000 (John Maddock).
406 Modified 11th September 2001 to be excluded when
407 BOOST_HAS_STDINT_H is defined (John Maddock).
408 Modified 11th Dec 2009 to always define the
409 INT#_C macros if they're not already defined (John Maddock).
410
411 ******************************************************/
412
413 #if !defined(BOOST__STDC_CONSTANT_MACROS_DEFINED) && \
414    (!defined(INT8_C) || !defined(INT16_C) || !defined(INT32_C) || !defined(INT64_C))
415 //
416 // For the following code we get several warnings along the lines of:
417 //
418 // boost/cstdint.hpp:428:35: error: use of C99 long long integer constant
419 //
420 // So we declare this a system header to suppress these warnings.
421 //
422 #if defined(__GNUC__) && (__GNUC__ >= 4)
423 #pragma GCC system_header
424 #endif
425
426 #include <limits.h>
427 # define BOOST__STDC_CONSTANT_MACROS_DEFINED
428 # if defined(BOOST_HAS_MS_INT64)
429 //
430 // Borland/Intel/Microsoft compilers have width specific suffixes:
431 //
432 #ifndef INT8_C
433 #  define INT8_C(value)     value##i8
434 #endif
435 #ifndef INT16_C
436 #  define INT16_C(value)    value##i16
437 #endif
438 #ifndef INT32_C
439 #  define INT32_C(value)    value##i32
440 #endif
441 #ifndef INT64_C
442 #  define INT64_C(value)    value##i64
443 #endif
444 #  ifdef __BORLANDC__
445     // Borland bug: appending ui8 makes the type a signed char
446 #   define UINT8_C(value)    static_cast<unsigned char>(value##u)
447 #  else
448 #   define UINT8_C(value)    value##ui8
449 #  endif
450 #ifndef UINT16_C
451 #  define UINT16_C(value)   value##ui16
452 #endif
453 #ifndef UINT32_C
454 #  define UINT32_C(value)   value##ui32
455 #endif
456 #ifndef UINT64_C
457 #  define UINT64_C(value)   value##ui64
458 #endif
459 #ifndef INTMAX_C
460 #  define INTMAX_C(value)   value##i64
461 #  define UINTMAX_C(value)  value##ui64
462 #endif
463
464 # else
465 //  do it the old fashioned way:
466
467 //  8-bit types  ------------------------------------------------------------//
468
469 #  if (UCHAR_MAX == 0xff) && !defined(INT8_C)
470 #   define INT8_C(value) static_cast<boost::int8_t>(value)
471 #   define UINT8_C(value) static_cast<boost::uint8_t>(value##u)
472 #  endif
473
474 //  16-bit types  -----------------------------------------------------------//
475
476 #  if (USHRT_MAX == 0xffff) && !defined(INT16_C)
477 #   define INT16_C(value) static_cast<boost::int16_t>(value)
478 #   define UINT16_C(value) static_cast<boost::uint16_t>(value##u)
479 #  endif
480
481 //  32-bit types  -----------------------------------------------------------//
482 #ifndef INT32_C
483 #  if (UINT_MAX == 0xffffffff)
484 #   define INT32_C(value) value
485 #   define UINT32_C(value) value##u
486 #  elif ULONG_MAX == 0xffffffff
487 #   define INT32_C(value) value##L
488 #   define UINT32_C(value) value##uL
489 #  endif
490 #endif
491
492 //  64-bit types + intmax_t and uintmax_t  ----------------------------------//
493 #ifndef INT64_C
494 #  if defined(BOOST_HAS_LONG_LONG) && \
495     (defined(ULLONG_MAX) || defined(ULONG_LONG_MAX) || defined(ULONGLONG_MAX) || defined(_LLONG_MAX))
496
497 #    if defined(__hpux)
498         // HP-UX's value of ULONG_LONG_MAX is unusable in preprocessor expressions
499 #       define INT64_C(value) value##LL
500 #       define UINT64_C(value) value##uLL
501 #    elif (defined(ULLONG_MAX) && ULLONG_MAX == 18446744073709551615ULL) ||  \
502         (defined(ULONG_LONG_MAX) && ULONG_LONG_MAX == 18446744073709551615ULL) ||  \
503         (defined(ULONGLONG_MAX) && ULONGLONG_MAX == 18446744073709551615ULL) || \
504         (defined(_LLONG_MAX) && _LLONG_MAX == 18446744073709551615ULL)
505
506 #       define INT64_C(value) value##LL
507 #       define UINT64_C(value) value##uLL
508 #    else
509 #       error defaults not correct; you must hand modify boost/cstdint.hpp
510 #    endif
511 #  elif ULONG_MAX != 0xffffffff
512
513 #    if ULONG_MAX == 18446744073709551615U // 2**64 - 1
514 #       define INT64_C(value) value##L
515 #       define UINT64_C(value) value##uL
516 #    else
517 #       error defaults not correct; you must hand modify boost/cstdint.hpp
518 #    endif
519 #  elif defined(BOOST_HAS_LONG_LONG)
520      // Usual macros not defined, work things out for ourselves:
521 #    if(~0uLL == 18446744073709551615ULL)
522 #       define INT64_C(value) value##LL
523 #       define UINT64_C(value) value##uLL
524 #    else
525 #       error defaults not correct; you must hand modify boost/cstdint.hpp
526 #    endif
527 #  else
528 #    error defaults not correct; you must hand modify boost/cstdint.hpp
529 #  endif
530
531 #  ifdef BOOST_NO_INT64_T
532 #   define INTMAX_C(value) INT32_C(value)
533 #   define UINTMAX_C(value) UINT32_C(value)
534 #  else
535 #   define INTMAX_C(value) INT64_C(value)
536 #   define UINTMAX_C(value) UINT64_C(value)
537 #  endif
538 #endif
539 # endif // Borland/Microsoft specific width suffixes
540
541 #endif // INT#_C macros.
542
543
544
545