am 34284954: am 76218efb: Merge "Fix inttypes.h and stdint.h for 64-bit (and C++11)."

* commit '34284954b3b43010d87c6f99a50dc673a55fbb04':
  Fix inttypes.h and stdint.h for 64-bit (and C++11).
This commit is contained in:
Elliott Hughes 2013-09-30 16:23:03 -07:00 committed by Android Git Automerger
commit b277509095
2 changed files with 65 additions and 50 deletions

View File

@ -22,7 +22,16 @@
#include <stdint.h> #include <stdint.h>
#include <sys/cdefs.h> #include <sys/cdefs.h>
#if !defined(__cplusplus) || defined(__STDC_FORMAT_MACROS) #if !defined(__cplusplus) || defined(__STDC_FORMAT_MACROS) || (__cplusplus >= 201103L)
#ifdef __LP64__
#define __PRI_64_prefix "l"
#define __PRI_PTR_prefix "l"
#else
#define __PRI_64_prefix "ll"
#define __PRI_PTR_prefix
#endif
/* /*
* 7.8.1 Macros for format specifiers * 7.8.1 Macros for format specifiers
* *
@ -43,203 +52,203 @@
#define PRId8 "d" /* int8_t */ #define PRId8 "d" /* int8_t */
#define PRId16 "d" /* int16_t */ #define PRId16 "d" /* int16_t */
#define PRId32 "d" /* int32_t */ #define PRId32 "d" /* int32_t */
#define PRId64 "lld" /* int64_t */ #define PRId64 __PRI_64_prefix"d" /* int64_t */
#define PRIdLEAST8 "d" /* int_least8_t */ #define PRIdLEAST8 "d" /* int_least8_t */
#define PRIdLEAST16 "d" /* int_least16_t */ #define PRIdLEAST16 "d" /* int_least16_t */
#define PRIdLEAST32 "d" /* int_least32_t */ #define PRIdLEAST32 "d" /* int_least32_t */
#define PRIdLEAST64 "lld" /* int_least64_t */ #define PRIdLEAST64 __PRI_64_prefix"d" /* int_least64_t */
#define PRIdFAST8 "d" /* int_fast8_t */ #define PRIdFAST8 "d" /* int_fast8_t */
#define PRIdFAST16 "d" /* int_fast16_t */ #define PRIdFAST16 "d" /* int_fast16_t */
#define PRIdFAST32 "d" /* int_fast32_t */ #define PRIdFAST32 "d" /* int_fast32_t */
#define PRIdFAST64 "lld" /* int_fast64_t */ #define PRIdFAST64 __PRI_64_prefix"d" /* int_fast64_t */
#define PRIdMAX "jd" /* intmax_t */ #define PRIdMAX "jd" /* intmax_t */
#define PRIdPTR "d" /* intptr_t */ #define PRIdPTR __PRI_PTR_prefix"d" /* intptr_t */
#define PRIi8 "i" /* int8_t */ #define PRIi8 "i" /* int8_t */
#define PRIi16 "i" /* int16_t */ #define PRIi16 "i" /* int16_t */
#define PRIi32 "i" /* int32_t */ #define PRIi32 "i" /* int32_t */
#define PRIi64 "lli" /* int64_t */ #define PRIi64 __PRI_64_prefix"i" /* int64_t */
#define PRIiLEAST8 "i" /* int_least8_t */ #define PRIiLEAST8 "i" /* int_least8_t */
#define PRIiLEAST16 "i" /* int_least16_t */ #define PRIiLEAST16 "i" /* int_least16_t */
#define PRIiLEAST32 "i" /* int_least32_t */ #define PRIiLEAST32 "i" /* int_least32_t */
#define PRIiLEAST64 "lli" /* int_least64_t */ #define PRIiLEAST64 __PRI_64_prefix"i" /* int_least64_t */
#define PRIiFAST8 "i" /* int_fast8_t */ #define PRIiFAST8 "i" /* int_fast8_t */
#define PRIiFAST16 "i" /* int_fast16_t */ #define PRIiFAST16 "i" /* int_fast16_t */
#define PRIiFAST32 "i" /* int_fast32_t */ #define PRIiFAST32 "i" /* int_fast32_t */
#define PRIiFAST64 "lli" /* int_fast64_t */ #define PRIiFAST64 __PRI_64_prefix"i" /* int_fast64_t */
#define PRIiMAX "ji" /* intmax_t */ #define PRIiMAX "ji" /* intmax_t */
#define PRIiPTR "i" /* intptr_t */ #define PRIiPTR __PRI_PTR_prefix"i" /* intptr_t */
/* fprintf macros for unsigned integers */ /* fprintf macros for unsigned integers */
#define PRIo8 "o" /* int8_t */ #define PRIo8 "o" /* int8_t */
#define PRIo16 "o" /* int16_t */ #define PRIo16 "o" /* int16_t */
#define PRIo32 "o" /* int32_t */ #define PRIo32 "o" /* int32_t */
#define PRIo64 "llo" /* int64_t */ #define PRIo64 __PRI_64_prefix"o" /* int64_t */
#define PRIoLEAST8 "o" /* int_least8_t */ #define PRIoLEAST8 "o" /* int_least8_t */
#define PRIoLEAST16 "o" /* int_least16_t */ #define PRIoLEAST16 "o" /* int_least16_t */
#define PRIoLEAST32 "o" /* int_least32_t */ #define PRIoLEAST32 "o" /* int_least32_t */
#define PRIoLEAST64 "llo" /* int_least64_t */ #define PRIoLEAST64 __PRI_64_prefix"o" /* int_least64_t */
#define PRIoFAST8 "o" /* int_fast8_t */ #define PRIoFAST8 "o" /* int_fast8_t */
#define PRIoFAST16 "o" /* int_fast16_t */ #define PRIoFAST16 "o" /* int_fast16_t */
#define PRIoFAST32 "o" /* int_fast32_t */ #define PRIoFAST32 "o" /* int_fast32_t */
#define PRIoFAST64 "llo" /* int_fast64_t */ #define PRIoFAST64 __PRI_64_prefix"o" /* int_fast64_t */
#define PRIoMAX "jo" /* intmax_t */ #define PRIoMAX "jo" /* intmax_t */
#define PRIoPTR "o" /* intptr_t */ #define PRIoPTR __PRI_PTR_prefix"o" /* intptr_t */
#define PRIu8 "u" /* uint8_t */ #define PRIu8 "u" /* uint8_t */
#define PRIu16 "u" /* uint16_t */ #define PRIu16 "u" /* uint16_t */
#define PRIu32 "u" /* uint32_t */ #define PRIu32 "u" /* uint32_t */
#define PRIu64 "llu" /* uint64_t */ #define PRIu64 __PRI_64_prefix"u" /* uint64_t */
#define PRIuLEAST8 "u" /* uint_least8_t */ #define PRIuLEAST8 "u" /* uint_least8_t */
#define PRIuLEAST16 "u" /* uint_least16_t */ #define PRIuLEAST16 "u" /* uint_least16_t */
#define PRIuLEAST32 "u" /* uint_least32_t */ #define PRIuLEAST32 "u" /* uint_least32_t */
#define PRIuLEAST64 "llu" /* uint_least64_t */ #define PRIuLEAST64 __PRI_64_prefix"u" /* uint_least64_t */
#define PRIuFAST8 "u" /* uint_fast8_t */ #define PRIuFAST8 "u" /* uint_fast8_t */
#define PRIuFAST16 "u" /* uint_fast16_t */ #define PRIuFAST16 "u" /* uint_fast16_t */
#define PRIuFAST32 "u" /* uint_fast32_t */ #define PRIuFAST32 "u" /* uint_fast32_t */
#define PRIuFAST64 "llu" /* uint_fast64_t */ #define PRIuFAST64 __PRI_64_prefix"u" /* uint_fast64_t */
#define PRIuMAX "ju" /* uintmax_t */ #define PRIuMAX "ju" /* uintmax_t */
#define PRIuPTR "u" /* uintptr_t */ #define PRIuPTR __PRI_PTR_prefix"u" /* uintptr_t */
#define PRIx8 "x" /* uint8_t */ #define PRIx8 "x" /* uint8_t */
#define PRIx16 "x" /* uint16_t */ #define PRIx16 "x" /* uint16_t */
#define PRIx32 "x" /* uint32_t */ #define PRIx32 "x" /* uint32_t */
#define PRIx64 "llx" /* uint64_t */ #define PRIx64 __PRI_64_prefix"x" /* uint64_t */
#define PRIxLEAST8 "x" /* uint_least8_t */ #define PRIxLEAST8 "x" /* uint_least8_t */
#define PRIxLEAST16 "x" /* uint_least16_t */ #define PRIxLEAST16 "x" /* uint_least16_t */
#define PRIxLEAST32 "x" /* uint_least32_t */ #define PRIxLEAST32 "x" /* uint_least32_t */
#define PRIxLEAST64 "llx" /* uint_least64_t */ #define PRIxLEAST64 __PRI_64_prefix"x" /* uint_least64_t */
#define PRIxFAST8 "x" /* uint_fast8_t */ #define PRIxFAST8 "x" /* uint_fast8_t */
#define PRIxFAST16 "x" /* uint_fast16_t */ #define PRIxFAST16 "x" /* uint_fast16_t */
#define PRIxFAST32 "x" /* uint_fast32_t */ #define PRIxFAST32 "x" /* uint_fast32_t */
#define PRIxFAST64 "llx" /* uint_fast64_t */ #define PRIxFAST64 __PRI_64_prefix"x" /* uint_fast64_t */
#define PRIxMAX "jx" /* uintmax_t */ #define PRIxMAX "jx" /* uintmax_t */
#define PRIxPTR "x" /* uintptr_t */ #define PRIxPTR __PRI_PTR_prefix"x" /* uintptr_t */
#define PRIX8 "X" /* uint8_t */ #define PRIX8 "X" /* uint8_t */
#define PRIX16 "X" /* uint16_t */ #define PRIX16 "X" /* uint16_t */
#define PRIX32 "X" /* uint32_t */ #define PRIX32 "X" /* uint32_t */
#define PRIX64 "llX" /* uint64_t */ #define PRIX64 __PRI_64_prefix"X" /* uint64_t */
#define PRIXLEAST8 "X" /* uint_least8_t */ #define PRIXLEAST8 "X" /* uint_least8_t */
#define PRIXLEAST16 "X" /* uint_least16_t */ #define PRIXLEAST16 "X" /* uint_least16_t */
#define PRIXLEAST32 "X" /* uint_least32_t */ #define PRIXLEAST32 "X" /* uint_least32_t */
#define PRIXLEAST64 "llX" /* uint_least64_t */ #define PRIXLEAST64 __PRI_64_prefix"X" /* uint_least64_t */
#define PRIXFAST8 "X" /* uint_fast8_t */ #define PRIXFAST8 "X" /* uint_fast8_t */
#define PRIXFAST16 "X" /* uint_fast16_t */ #define PRIXFAST16 "X" /* uint_fast16_t */
#define PRIXFAST32 "X" /* uint_fast32_t */ #define PRIXFAST32 "X" /* uint_fast32_t */
#define PRIXFAST64 "llX" /* uint_fast64_t */ #define PRIXFAST64 __PRI_64_prefix"X" /* uint_fast64_t */
#define PRIXMAX "jX" /* uintmax_t */ #define PRIXMAX "jX" /* uintmax_t */
#define PRIXPTR "X" /* uintptr_t */ #define PRIXPTR __PRI_PTR_prefix"X" /* uintptr_t */
/* fscanf macros for signed integers */ /* fscanf macros for signed integers */
#define SCNd8 "hhd" /* int8_t */ #define SCNd8 "hhd" /* int8_t */
#define SCNd16 "hd" /* int16_t */ #define SCNd16 "hd" /* int16_t */
#define SCNd32 "d" /* int32_t */ #define SCNd32 "d" /* int32_t */
#define SCNd64 "lld" /* int64_t */ #define SCNd64 __PRI_64_prefix"d" /* int64_t */
#define SCNdLEAST8 "hhd" /* int_least8_t */ #define SCNdLEAST8 "hhd" /* int_least8_t */
#define SCNdLEAST16 "hd" /* int_least16_t */ #define SCNdLEAST16 "hd" /* int_least16_t */
#define SCNdLEAST32 "d" /* int_least32_t */ #define SCNdLEAST32 "d" /* int_least32_t */
#define SCNdLEAST64 "lld" /* int_least64_t */ #define SCNdLEAST64 __PRI_64_prefix"d" /* int_least64_t */
#define SCNdFAST8 "hhd" /* int_fast8_t */ #define SCNdFAST8 "hhd" /* int_fast8_t */
#define SCNdFAST16 "hd" /* int_fast16_t */ #define SCNdFAST16 "hd" /* int_fast16_t */
#define SCNdFAST32 "d" /* int_fast32_t */ #define SCNdFAST32 "d" /* int_fast32_t */
#define SCNdFAST64 "lld" /* int_fast64_t */ #define SCNdFAST64 __PRI_64_prefix"d" /* int_fast64_t */
#define SCNdMAX "jd" /* intmax_t */ #define SCNdMAX "jd" /* intmax_t */
#define SCNdPTR "d" /* intptr_t */ #define SCNdPTR __PRI_PTR_prefix"d" /* intptr_t */
#define SCNi8 "hhi" /* int8_t */ #define SCNi8 "hhi" /* int8_t */
#define SCNi16 "hi" /* int16_t */ #define SCNi16 "hi" /* int16_t */
#define SCNi32 "i" /* int32_t */ #define SCNi32 "i" /* int32_t */
#define SCNi64 "lli" /* int64_t */ #define SCNi64 __PRI_64_prefix"i" /* int64_t */
#define SCNiLEAST8 "hhi" /* int_least8_t */ #define SCNiLEAST8 "hhi" /* int_least8_t */
#define SCNiLEAST16 "hi" /* int_least16_t */ #define SCNiLEAST16 "hi" /* int_least16_t */
#define SCNiLEAST32 "i" /* int_least32_t */ #define SCNiLEAST32 "i" /* int_least32_t */
#define SCNiLEAST64 "lli" /* int_least64_t */ #define SCNiLEAST64 __PRI_64_prefix"i" /* int_least64_t */
#define SCNiFAST8 "hhi" /* int_fast8_t */ #define SCNiFAST8 "hhi" /* int_fast8_t */
#define SCNiFAST16 "hi" /* int_fast16_t */ #define SCNiFAST16 "hi" /* int_fast16_t */
#define SCNiFAST32 "i" /* int_fast32_t */ #define SCNiFAST32 "i" /* int_fast32_t */
#define SCNiFAST64 "lli" /* int_fast64_t */ #define SCNiFAST64 __PRI_64_prefix"i" /* int_fast64_t */
#define SCNiMAX "ji" /* intmax_t */ #define SCNiMAX "ji" /* intmax_t */
#define SCNiPTR "i" /* intptr_t */ #define SCNiPTR __PRI_PTR_prefix"i" /* intptr_t */
/* fscanf macros for unsigned integers */ /* fscanf macros for unsigned integers */
#define SCNo8 "hho" /* uint8_t */ #define SCNo8 "hho" /* uint8_t */
#define SCNo16 "ho" /* uint16_t */ #define SCNo16 "ho" /* uint16_t */
#define SCNo32 "o" /* uint32_t */ #define SCNo32 "o" /* uint32_t */
#define SCNo64 "llo" /* uint64_t */ #define SCNo64 __PRI_64_prefix"o" /* uint64_t */
#define SCNoLEAST8 "hho" /* uint_least8_t */ #define SCNoLEAST8 "hho" /* uint_least8_t */
#define SCNoLEAST16 "ho" /* uint_least16_t */ #define SCNoLEAST16 "ho" /* uint_least16_t */
#define SCNoLEAST32 "o" /* uint_least32_t */ #define SCNoLEAST32 "o" /* uint_least32_t */
#define SCNoLEAST64 "llo" /* uint_least64_t */ #define SCNoLEAST64 __PRI_64_prefix"o" /* uint_least64_t */
#define SCNoFAST8 "hho" /* uint_fast8_t */ #define SCNoFAST8 "hho" /* uint_fast8_t */
#define SCNoFAST16 "ho" /* uint_fast16_t */ #define SCNoFAST16 "ho" /* uint_fast16_t */
#define SCNoFAST32 "o" /* uint_fast32_t */ #define SCNoFAST32 "o" /* uint_fast32_t */
#define SCNoFAST64 "llo" /* uint_fast64_t */ #define SCNoFAST64 __PRI_64_prefix"o" /* uint_fast64_t */
#define SCNoMAX "jo" /* uintmax_t */ #define SCNoMAX "jo" /* uintmax_t */
#define SCNoPTR "o" /* uintptr_t */ #define SCNoPTR __PRI_PTR_prefix"o" /* uintptr_t */
#define SCNu8 "hhu" /* uint8_t */ #define SCNu8 "hhu" /* uint8_t */
#define SCNu16 "hu" /* uint16_t */ #define SCNu16 "hu" /* uint16_t */
#define SCNu32 "u" /* uint32_t */ #define SCNu32 "u" /* uint32_t */
#define SCNu64 "llu" /* uint64_t */ #define SCNu64 __PRI_64_prefix"u" /* uint64_t */
#define SCNuLEAST8 "hhu" /* uint_least8_t */ #define SCNuLEAST8 "hhu" /* uint_least8_t */
#define SCNuLEAST16 "hu" /* uint_least16_t */ #define SCNuLEAST16 "hu" /* uint_least16_t */
#define SCNuLEAST32 "u" /* uint_least32_t */ #define SCNuLEAST32 "u" /* uint_least32_t */
#define SCNuLEAST64 "llu" /* uint_least64_t */ #define SCNuLEAST64 __PRI_64_prefix"u" /* uint_least64_t */
#define SCNuFAST8 "hhu" /* uint_fast8_t */ #define SCNuFAST8 "hhu" /* uint_fast8_t */
#define SCNuFAST16 "hu" /* uint_fast16_t */ #define SCNuFAST16 "hu" /* uint_fast16_t */
#define SCNuFAST32 "u" /* uint_fast32_t */ #define SCNuFAST32 "u" /* uint_fast32_t */
#define SCNuFAST64 "llu" /* uint_fast64_t */ #define SCNuFAST64 __PRI_64_prefix"u" /* uint_fast64_t */
#define SCNuMAX "ju" /* uintmax_t */ #define SCNuMAX "ju" /* uintmax_t */
#define SCNuPTR "u" /* uintptr_t */ #define SCNuPTR __PRI_PTR_prefix"u" /* uintptr_t */
#define SCNx8 "hhx" /* uint8_t */ #define SCNx8 "hhx" /* uint8_t */
#define SCNx16 "hx" /* uint16_t */ #define SCNx16 "hx" /* uint16_t */
#define SCNx32 "x" /* uint32_t */ #define SCNx32 "x" /* uint32_t */
#define SCNx64 "llx" /* uint64_t */ #define SCNx64 __PRI_64_prefix"x" /* uint64_t */
#define SCNxLEAST8 "hhx" /* uint_least8_t */ #define SCNxLEAST8 "hhx" /* uint_least8_t */
#define SCNxLEAST16 "hx" /* uint_least16_t */ #define SCNxLEAST16 "hx" /* uint_least16_t */
#define SCNxLEAST32 "x" /* uint_least32_t */ #define SCNxLEAST32 "x" /* uint_least32_t */
#define SCNxLEAST64 "llx" /* uint_least64_t */ #define SCNxLEAST64 __PRI_64_prefix"x" /* uint_least64_t */
#define SCNxFAST8 "hhx" /* uint_fast8_t */ #define SCNxFAST8 "hhx" /* uint_fast8_t */
#define SCNxFAST16 "hx" /* uint_fast16_t */ #define SCNxFAST16 "hx" /* uint_fast16_t */
#define SCNxFAST32 "x" /* uint_fast32_t */ #define SCNxFAST32 "x" /* uint_fast32_t */
#define SCNxFAST64 "llx" /* uint_fast64_t */ #define SCNxFAST64 __PRI_64_prefix"x" /* uint_fast64_t */
#define SCNxMAX "jx" /* uintmax_t */ #define SCNxMAX "jx" /* uintmax_t */
#define SCNxPTR "x" /* uintptr_t */ #define SCNxPTR __PRI_PTR_prefix"x" /* uintptr_t */
#endif /* __cplusplus || __STDC_FORMAT_MACROS */ #endif /* __cplusplus || __STDC_FORMAT_MACROS */

View File

@ -25,17 +25,18 @@
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
*/ */
#ifndef _STDINT_H #ifndef _STDINT_H
#define _STDINT_H #define _STDINT_H
#include <stddef.h> #include <stddef.h>
#include <sys/_types.h> #include <sys/_types.h>
#if !defined(__cplusplus) || defined(__STDC_LIMIT_MACROS) #if !defined(__cplusplus) || defined(__STDC_LIMIT_MACROS) || (__cplusplus >= 201103L)
# define __STDINT_LIMITS # define __STDINT_LIMITS
#endif #endif
#if !defined(__cplusplus) || defined(__STDC_CONSTANT_MACROS) #if !defined(__cplusplus) || defined(__STDC_CONSTANT_MACROS) || (__cplusplus >= 201103L)
# define __STDINT_MACROS # define __STDINT_MACROS
#endif #endif
@ -157,6 +158,14 @@ typedef int64_t int_fast64_t;
typedef uint64_t uint_least64_t; typedef uint64_t uint_least64_t;
typedef uint64_t uint_fast64_t; typedef uint64_t uint_fast64_t;
#if __LP64__
# define __INT64_C(c) c ## L
# define __UINT64_C(c) c ## UL
#else
# define __INT64_C(c) c ## LL
# define __UINT64_C(c) c ## ULL
#endif
#ifdef __STDINT_LIMITS #ifdef __STDINT_LIMITS
# define INT64_MIN (__INT64_C(-9223372036854775807)-1) # define INT64_MIN (__INT64_C(-9223372036854775807)-1)
# define INT64_MAX (__INT64_C(9223372036854775807)) # define INT64_MAX (__INT64_C(9223372036854775807))
@ -170,9 +179,6 @@ typedef uint64_t uint_fast64_t;
# define UINT_FAST64_MAX UINT64_MAX # define UINT_FAST64_MAX UINT64_MAX
#endif #endif
#define __INT64_C(c) c ## LL
#define __UINT64_C(c) c ## ULL
#ifdef __STDINT_MACROS #ifdef __STDINT_MACROS
# define INT64_C(c) __INT64_C(c) # define INT64_C(c) __INT64_C(c)
# define INT_LEAST64_C(c) INT64_C(c) # define INT_LEAST64_C(c) INT64_C(c)