Fix inttypes.h PRI?PTR and SCN?PTR macros.
Our intptr_t and uintptr_t aren't "long". Add a compilation test so we remember to fix this to cope with 32- and 64-bit later. Bug: http://code.google.com/p/android/issues/detail?id=57218 Change-Id: I2f816d339edb4f7d57e4418b818fb4c602093f38
This commit is contained in:
parent
1ba3a2c269
commit
74f0833df6
|
@ -56,7 +56,7 @@
|
||||||
#define PRIdFAST64 "lld" /* int_fast64_t */
|
#define PRIdFAST64 "lld" /* int_fast64_t */
|
||||||
|
|
||||||
#define PRIdMAX "jd" /* intmax_t */
|
#define PRIdMAX "jd" /* intmax_t */
|
||||||
#define PRIdPTR "ld" /* intptr_t */
|
#define PRIdPTR "d" /* intptr_t */
|
||||||
|
|
||||||
#define PRIi8 "i" /* int8_t */
|
#define PRIi8 "i" /* int8_t */
|
||||||
#define PRIi16 "i" /* int16_t */
|
#define PRIi16 "i" /* int16_t */
|
||||||
|
@ -74,7 +74,7 @@
|
||||||
#define PRIiFAST64 "lli" /* int_fast64_t */
|
#define PRIiFAST64 "lli" /* int_fast64_t */
|
||||||
|
|
||||||
#define PRIiMAX "ji" /* intmax_t */
|
#define PRIiMAX "ji" /* intmax_t */
|
||||||
#define PRIiPTR "li" /* intptr_t */
|
#define PRIiPTR "i" /* intptr_t */
|
||||||
|
|
||||||
/* fprintf macros for unsigned integers */
|
/* fprintf macros for unsigned integers */
|
||||||
#define PRIo8 "o" /* int8_t */
|
#define PRIo8 "o" /* int8_t */
|
||||||
|
@ -93,7 +93,7 @@
|
||||||
#define PRIoFAST64 "llo" /* int_fast64_t */
|
#define PRIoFAST64 "llo" /* int_fast64_t */
|
||||||
|
|
||||||
#define PRIoMAX "jo" /* intmax_t */
|
#define PRIoMAX "jo" /* intmax_t */
|
||||||
#define PRIoPTR "lo" /* intptr_t */
|
#define PRIoPTR "o" /* intptr_t */
|
||||||
|
|
||||||
#define PRIu8 "u" /* uint8_t */
|
#define PRIu8 "u" /* uint8_t */
|
||||||
#define PRIu16 "u" /* uint16_t */
|
#define PRIu16 "u" /* uint16_t */
|
||||||
|
@ -111,7 +111,7 @@
|
||||||
#define PRIuFAST64 "llu" /* uint_fast64_t */
|
#define PRIuFAST64 "llu" /* uint_fast64_t */
|
||||||
|
|
||||||
#define PRIuMAX "ju" /* uintmax_t */
|
#define PRIuMAX "ju" /* uintmax_t */
|
||||||
#define PRIuPTR "lu" /* uintptr_t */
|
#define PRIuPTR "u" /* uintptr_t */
|
||||||
|
|
||||||
#define PRIx8 "x" /* uint8_t */
|
#define PRIx8 "x" /* uint8_t */
|
||||||
#define PRIx16 "x" /* uint16_t */
|
#define PRIx16 "x" /* uint16_t */
|
||||||
|
@ -129,7 +129,7 @@
|
||||||
#define PRIxFAST64 "llx" /* uint_fast64_t */
|
#define PRIxFAST64 "llx" /* uint_fast64_t */
|
||||||
|
|
||||||
#define PRIxMAX "jx" /* uintmax_t */
|
#define PRIxMAX "jx" /* uintmax_t */
|
||||||
#define PRIxPTR "lx" /* uintptr_t */
|
#define PRIxPTR "x" /* uintptr_t */
|
||||||
|
|
||||||
#define PRIX8 "X" /* uint8_t */
|
#define PRIX8 "X" /* uint8_t */
|
||||||
#define PRIX16 "X" /* uint16_t */
|
#define PRIX16 "X" /* uint16_t */
|
||||||
|
@ -147,7 +147,7 @@
|
||||||
#define PRIXFAST64 "llX" /* uint_fast64_t */
|
#define PRIXFAST64 "llX" /* uint_fast64_t */
|
||||||
|
|
||||||
#define PRIXMAX "jX" /* uintmax_t */
|
#define PRIXMAX "jX" /* uintmax_t */
|
||||||
#define PRIXPTR "lX" /* uintptr_t */
|
#define PRIXPTR "X" /* uintptr_t */
|
||||||
|
|
||||||
/* fscanf macros for signed integers */
|
/* fscanf macros for signed integers */
|
||||||
#define SCNd8 "hhd" /* int8_t */
|
#define SCNd8 "hhd" /* int8_t */
|
||||||
|
@ -166,7 +166,7 @@
|
||||||
#define SCNdFAST64 "lld" /* int_fast64_t */
|
#define SCNdFAST64 "lld" /* int_fast64_t */
|
||||||
|
|
||||||
#define SCNdMAX "jd" /* intmax_t */
|
#define SCNdMAX "jd" /* intmax_t */
|
||||||
#define SCNdPTR "ld" /* intptr_t */
|
#define SCNdPTR "d" /* intptr_t */
|
||||||
|
|
||||||
#define SCNi8 "hhi" /* int8_t */
|
#define SCNi8 "hhi" /* int8_t */
|
||||||
#define SCNi16 "hi" /* int16_t */
|
#define SCNi16 "hi" /* int16_t */
|
||||||
|
@ -184,7 +184,7 @@
|
||||||
#define SCNiFAST64 "lli" /* int_fast64_t */
|
#define SCNiFAST64 "lli" /* int_fast64_t */
|
||||||
|
|
||||||
#define SCNiMAX "ji" /* intmax_t */
|
#define SCNiMAX "ji" /* intmax_t */
|
||||||
#define SCNiPTR "li" /* intptr_t */
|
#define SCNiPTR "i" /* intptr_t */
|
||||||
|
|
||||||
/* fscanf macros for unsigned integers */
|
/* fscanf macros for unsigned integers */
|
||||||
#define SCNo8 "hho" /* uint8_t */
|
#define SCNo8 "hho" /* uint8_t */
|
||||||
|
@ -203,7 +203,7 @@
|
||||||
#define SCNoFAST64 "llo" /* uint_fast64_t */
|
#define SCNoFAST64 "llo" /* uint_fast64_t */
|
||||||
|
|
||||||
#define SCNoMAX "jo" /* uintmax_t */
|
#define SCNoMAX "jo" /* uintmax_t */
|
||||||
#define SCNoPTR "lo" /* uintptr_t */
|
#define SCNoPTR "o" /* uintptr_t */
|
||||||
|
|
||||||
#define SCNu8 "hhu" /* uint8_t */
|
#define SCNu8 "hhu" /* uint8_t */
|
||||||
#define SCNu16 "hu" /* uint16_t */
|
#define SCNu16 "hu" /* uint16_t */
|
||||||
|
@ -221,7 +221,7 @@
|
||||||
#define SCNuFAST64 "llu" /* uint_fast64_t */
|
#define SCNuFAST64 "llu" /* uint_fast64_t */
|
||||||
|
|
||||||
#define SCNuMAX "ju" /* uintmax_t */
|
#define SCNuMAX "ju" /* uintmax_t */
|
||||||
#define SCNuPTR "lu" /* uintptr_t */
|
#define SCNuPTR "u" /* uintptr_t */
|
||||||
|
|
||||||
#define SCNx8 "hhx" /* uint8_t */
|
#define SCNx8 "hhx" /* uint8_t */
|
||||||
#define SCNx16 "hx" /* uint16_t */
|
#define SCNx16 "hx" /* uint16_t */
|
||||||
|
@ -239,7 +239,7 @@
|
||||||
#define SCNxFAST64 "llx" /* uint_fast64_t */
|
#define SCNxFAST64 "llx" /* uint_fast64_t */
|
||||||
|
|
||||||
#define SCNxMAX "jx" /* uintmax_t */
|
#define SCNxMAX "jx" /* uintmax_t */
|
||||||
#define SCNxPTR "lx" /* uintptr_t */
|
#define SCNxPTR "x" /* uintptr_t */
|
||||||
|
|
||||||
#endif /* __cplusplus || __STDC_FORMAT_MACROS */
|
#endif /* __cplusplus || __STDC_FORMAT_MACROS */
|
||||||
|
|
||||||
|
|
|
@ -63,6 +63,7 @@ test_src_files = \
|
||||||
fenv_test.cpp \
|
fenv_test.cpp \
|
||||||
getauxval_test.cpp \
|
getauxval_test.cpp \
|
||||||
getcwd_test.cpp \
|
getcwd_test.cpp \
|
||||||
|
inttypes_test.cpp \
|
||||||
libc_logging_test.cpp \
|
libc_logging_test.cpp \
|
||||||
libgen_test.cpp \
|
libgen_test.cpp \
|
||||||
malloc_test.cpp \
|
malloc_test.cpp \
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2013 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
#define __STDC_FORMAT_MACROS // Otherwise not available in C++.
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <inttypes.h>
|
||||||
|
|
||||||
|
#if defined(__BIONIC__) // Doesn't work on glibc because we use -m32.
|
||||||
|
TEST(inttypes, misc) {
|
||||||
|
char buf[512];
|
||||||
|
|
||||||
|
intptr_t i = 0;
|
||||||
|
uintptr_t u = 0;
|
||||||
|
|
||||||
|
snprintf(buf, sizeof(buf), "%08" PRIdPTR, i);
|
||||||
|
snprintf(buf, sizeof(buf), "%08" PRIiPTR, i);
|
||||||
|
snprintf(buf, sizeof(buf), "%08" PRIoPTR, i);
|
||||||
|
snprintf(buf, sizeof(buf), "%08" PRIuPTR, u);
|
||||||
|
snprintf(buf, sizeof(buf), "%08" PRIxPTR, u);
|
||||||
|
snprintf(buf, sizeof(buf), "%08" PRIXPTR, u);
|
||||||
|
|
||||||
|
sscanf(buf, "%08" SCNdPTR, &i);
|
||||||
|
sscanf(buf, "%08" SCNiPTR, &i);
|
||||||
|
sscanf(buf, "%08" SCNoPTR, &u);
|
||||||
|
sscanf(buf, "%08" SCNuPTR, &u);
|
||||||
|
sscanf(buf, "%08" SCNxPTR, &u);
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
Reference in New Issue