| Index: webrtc/base/basictypes.h
|
| diff --git a/webrtc/base/basictypes.h b/webrtc/base/basictypes.h
|
| index 66f2ff4b248115736cc70b12c5da84863cea76c9..cddde9c04aace6008a2f95c15cb573863f54cd9e 100644
|
| --- a/webrtc/base/basictypes.h
|
| +++ b/webrtc/base/basictypes.h
|
| @@ -12,97 +12,51 @@
|
| #define WEBRTC_BASE_BASICTYPES_H_
|
|
|
| #include <stddef.h> // for NULL, size_t
|
| -
|
| -#if !(defined(_MSC_VER) && (_MSC_VER < 1600))
|
| #include <stdint.h> // for uintptr_t
|
| -#endif
|
|
|
| #ifdef HAVE_CONFIG_H
|
| #include "config.h" // NOLINT
|
| #endif
|
|
|
| -#include "webrtc/base/constructormagic.h"
|
| -
|
| -#if !defined(INT_TYPES_DEFINED)
|
| -#define INT_TYPES_DEFINED
|
| -#ifdef COMPILER_MSVC
|
| -typedef unsigned __int64 uint64;
|
| -typedef __int64 int64;
|
| -#ifndef INT64_C
|
| -#define INT64_C(x) x ## I64
|
| -#endif
|
| -#ifndef UINT64_C
|
| -#define UINT64_C(x) x ## UI64
|
| -#endif
|
| -#define INT64_F "I64"
|
| -#else // COMPILER_MSVC
|
| -// On Mac OS X, cssmconfig.h defines uint64 as uint64_t
|
| -// TODO(fbarchard): Use long long for compatibility with chromium on BSD/OSX.
|
| -#if defined(WEBRTC_MAC) && !defined(WEBRTC_IOS)
|
| -typedef uint64_t uint64;
|
| +// TODO(grunell): Use (u)intxx_t everywhere instead and remove these typedefs.
|
| +typedef int8_t int8;
|
| +typedef uint8_t uint8;
|
| +typedef int16_t int16;
|
| +typedef uint16_t uint16;
|
| +typedef int32_t int32;
|
| +typedef uint32_t uint32;
|
| typedef int64_t int64;
|
| -#ifndef INT64_C
|
| -#define INT64_C(x) x ## LL
|
| -#endif
|
| -#ifndef UINT64_C
|
| -#define UINT64_C(x) x ## ULL
|
| -#endif
|
| -#define INT64_F "l"
|
| -#elif defined(__LP64__)
|
| -typedef unsigned long long uint64; // NOLINT
|
| -typedef long long int64; // NOLINT
|
| -#ifndef INT64_C
|
| -#define INT64_C(x) x ## L
|
| -#endif
|
| -#ifndef UINT64_C
|
| -#define UINT64_C(x) x ## UL
|
| -#endif
|
| -#define INT64_F "l"
|
| -#else // __LP64__
|
| -typedef unsigned long long uint64; // NOLINT
|
| -typedef long long int64; // NOLINT
|
| -#ifndef INT64_C
|
| -#define INT64_C(x) x ## LL
|
| -#endif
|
| -#ifndef UINT64_C
|
| -#define UINT64_C(x) x ## ULL
|
| -#endif
|
| -#define INT64_F "ll"
|
| -#endif // __LP64__
|
| -#endif // COMPILER_MSVC
|
| -typedef unsigned int uint32;
|
| -typedef int int32;
|
| -typedef unsigned short uint16; // NOLINT
|
| -typedef short int16; // NOLINT
|
| -typedef unsigned char uint8;
|
| -typedef signed char int8;
|
| -#endif // INT_TYPES_DEFINED
|
| +typedef uint64_t uint64;
|
|
|
| // Detect compiler is for x86 or x64.
|
| #if defined(__x86_64__) || defined(_M_X64) || \
|
| defined(__i386__) || defined(_M_IX86)
|
| #define CPU_X86 1
|
| #endif
|
| +
|
| // Detect compiler is for arm.
|
| #if defined(__arm__) || defined(_M_ARM)
|
| #define CPU_ARM 1
|
| #endif
|
| +
|
| #if defined(CPU_X86) && defined(CPU_ARM)
|
| #error CPU_X86 and CPU_ARM both defined.
|
| #endif
|
| -#if !defined(ARCH_CPU_BIG_ENDIAN) && !defined(ARCH_CPU_LITTLE_ENDIAN)
|
| +
|
| +#if !defined(RTC_ARCH_CPU_BIG_ENDIAN) && !defined(RTC_ARCH_CPU_LITTLE_ENDIAN)
|
| // x86, arm or GCC provided __BYTE_ORDER__ macros
|
| #if CPU_X86 || CPU_ARM || \
|
| (defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__)
|
| -#define ARCH_CPU_LITTLE_ENDIAN
|
| +#define RTC_ARCH_CPU_LITTLE_ENDIAN
|
| #elif defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
|
| -#define ARCH_CPU_BIG_ENDIAN
|
| +#define RTC_ARCH_CPU_BIG_ENDIAN
|
| #else
|
| -#error ARCH_CPU_BIG_ENDIAN or ARCH_CPU_LITTLE_ENDIAN should be defined.
|
| +#error RTC_ARCH_CPU_BIG_ENDIAN or RTC_ARCH_CPU_LITTLE_ENDIAN should be defined.
|
| #endif
|
| #endif
|
| -#if defined(ARCH_CPU_BIG_ENDIAN) && defined(ARCH_CPU_LITTLE_ENDIAN)
|
| -#error ARCH_CPU_BIG_ENDIAN and ARCH_CPU_LITTLE_ENDIAN both defined.
|
| +
|
| +#if defined(RTC_ARCH_CPU_BIG_ENDIAN) && defined(RTC_ARCH_CPU_LITTLE_ENDIAN)
|
| +#error RTC_ARCH_CPU_BIG_ENDIAN and RTC_ARCH_CPU_LITTLE_ENDIAN both defined.
|
| #endif
|
|
|
| #if defined(WEBRTC_WIN)
|
| @@ -111,17 +65,20 @@ typedef int socklen_t;
|
|
|
| // The following only works for C++
|
| #ifdef __cplusplus
|
| +
|
| #ifndef ALIGNP
|
| -#define ALIGNP(p, t) \
|
| - (reinterpret_cast<uint8*>(((reinterpret_cast<uintptr_t>(p) + \
|
| - ((t) - 1)) & ~((t) - 1))))
|
| +#define ALIGNP(p, t) \
|
| + (reinterpret_cast<uint8_t*>(((reinterpret_cast<uintptr_t>(p) + \
|
| + ((t) - 1)) & ~((t) - 1))))
|
| #endif
|
| +
|
| #define RTC_IS_ALIGNED(p, a) (!((uintptr_t)(p) & ((a) - 1)))
|
|
|
| -// Use these to declare and define a static local variable (static T;) so that
|
| -// it is leaked so that its destructors are not called at exit.
|
| +// Use these to declare and define a static local variable that gets leaked so
|
| +// that its destructors are not called at exit.
|
| #define RTC_DEFINE_STATIC_LOCAL(type, name, arguments) \
|
| static type& name = *new type arguments
|
|
|
| #endif // __cplusplus
|
| +
|
| #endif // WEBRTC_BASE_BASICTYPES_H_
|
|
|