Index: build/build_config.h |
diff --git a/build/build_config.h b/build/build_config.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d8c3db6ed781791bd8f37dc9cb28511fe5f553c4 |
--- /dev/null |
+++ b/build/build_config.h |
@@ -0,0 +1,168 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+// This file adds defines about the platform we're currently building on. |
+// Operating System: |
+// OS_WIN / OS_MACOSX / OS_LINUX / OS_POSIX (MACOSX or LINUX) / |
+// OS_NACL (NACL_SFI or NACL_NONSFI) / OS_NACL_SFI / OS_NACL_NONSFI |
+// Compiler: |
+// COMPILER_MSVC / COMPILER_GCC |
+// Processor: |
+// ARCH_CPU_X86 / ARCH_CPU_X86_64 / ARCH_CPU_X86_FAMILY (X86 or X86_64) |
+// ARCH_CPU_32_BITS / ARCH_CPU_64_BITS |
+ |
+#ifndef BUILD_BUILD_CONFIG_H_ |
+#define BUILD_BUILD_CONFIG_H_ |
+ |
+// A set of macros to use for platform detection. |
+#if defined(__native_client__) |
+// __native_client__ must be first, so that other OS_ defines are not set. |
+#define OS_NACL 1 |
+// OS_NACL comes in two sandboxing technology flavors, SFI or Non-SFI. |
+// PNaCl toolchain defines __native_client_nonsfi__ macro in Non-SFI build |
+// mode, while it does not in SFI build mode. |
+#if defined(__native_client_nonsfi__) |
+#define OS_NACL_NONSFI |
+#else |
+#define OS_NACL_SFI |
+#endif |
+#elif defined(ANDROID) |
+#define OS_ANDROID 1 |
+#elif defined(__APPLE__) |
+// only include TargetConditions after testing ANDROID as some android builds |
+// on mac don't have this header available and it's not needed unless the target |
+// is really mac/ios. |
+#include <TargetConditionals.h> |
+#define OS_MACOSX 1 |
+#if defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE |
+#define OS_IOS 1 |
+#endif // defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE |
+#elif defined(__linux__) |
+#define OS_LINUX 1 |
+// include a system header to pull in features.h for glibc/uclibc macros. |
+#include <unistd.h> |
+#if defined(__GLIBC__) && !defined(__UCLIBC__) |
+// we really are using glibc, not uClibc pretending to be glibc |
+#define LIBC_GLIBC 1 |
+#endif |
+#elif defined(_WIN32) |
+#define OS_WIN 1 |
+#define TOOLKIT_VIEWS 1 |
+#elif defined(__FreeBSD__) |
+#define OS_FREEBSD 1 |
+#elif defined(__OpenBSD__) |
+#define OS_OPENBSD 1 |
+#elif defined(__sun) |
+#define OS_SOLARIS 1 |
+#elif defined(__QNXNTO__) |
+#define OS_QNX 1 |
+#else |
+#error Please add support for your platform in build/build_config.h |
+#endif |
+ |
+#if defined(USE_OPENSSL_CERTS) && defined(USE_NSS_CERTS) |
+#error Cannot use both OpenSSL and NSS for certificates |
+#endif |
+ |
+// For access to standard BSD features, use OS_BSD instead of a |
+// more specific macro. |
+#if defined(OS_FREEBSD) || defined(OS_OPENBSD) |
+#define OS_BSD 1 |
+#endif |
+ |
+// For access to standard POSIXish features, use OS_POSIX instead of a |
+// more specific macro. |
+#if defined(OS_MACOSX) || defined(OS_LINUX) || defined(OS_FREEBSD) || \ |
+ defined(OS_OPENBSD) || defined(OS_SOLARIS) || defined(OS_ANDROID) || \ |
+ defined(OS_NACL) || defined(OS_QNX) |
+#define OS_POSIX 1 |
+#endif |
+ |
+// Use tcmalloc |
+#if (defined(OS_WIN) || defined(OS_LINUX) || defined(OS_ANDROID)) && \ |
+ !defined(NO_TCMALLOC) |
+#define USE_TCMALLOC 1 |
+#endif |
+ |
+// Compiler detection. |
+#if defined(__GNUC__) |
+#define COMPILER_GCC 1 |
+#elif defined(_MSC_VER) |
+#define COMPILER_MSVC 1 |
+#else |
+#error Please add support for your compiler in build/build_config.h |
+#endif |
+ |
+// Processor architecture detection. For more info on what's defined, see: |
+// http://msdn.microsoft.com/en-us/library/b0084kay.aspx |
+// http://www.agner.org/optimize/calling_conventions.pdf |
+// or with gcc, run: "echo | gcc -E -dM -" |
+#if defined(_M_X64) || defined(__x86_64__) |
+#define ARCH_CPU_X86_FAMILY 1 |
+#define ARCH_CPU_X86_64 1 |
+#define ARCH_CPU_64_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#elif defined(_M_IX86) || defined(__i386__) |
+#define ARCH_CPU_X86_FAMILY 1 |
+#define ARCH_CPU_X86 1 |
+#define ARCH_CPU_32_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#elif defined(__ARMEL__) |
+#define ARCH_CPU_ARM_FAMILY 1 |
+#define ARCH_CPU_ARMEL 1 |
+#define ARCH_CPU_32_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#elif defined(__aarch64__) |
+#define ARCH_CPU_ARM_FAMILY 1 |
+#define ARCH_CPU_ARM64 1 |
+#define ARCH_CPU_64_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#elif defined(__pnacl__) |
+#define ARCH_CPU_32_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#elif defined(__MIPSEL__) |
+#if defined(__LP64__) |
+#define ARCH_CPU_MIPS64_FAMILY 1 |
+#define ARCH_CPU_MIPS64EL 1 |
+#define ARCH_CPU_64_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#else |
+#define ARCH_CPU_MIPS_FAMILY 1 |
+#define ARCH_CPU_MIPSEL 1 |
+#define ARCH_CPU_32_BITS 1 |
+#define ARCH_CPU_LITTLE_ENDIAN 1 |
+#endif |
+#else |
+#error Please add support for your architecture in build/build_config.h |
+#endif |
+ |
+// Type detection for wchar_t. |
+#if defined(OS_WIN) |
+#define WCHAR_T_IS_UTF16 |
+#elif defined(OS_POSIX) && defined(COMPILER_GCC) && \ |
+ defined(__WCHAR_MAX__) && \ |
+ (__WCHAR_MAX__ == 0x7fffffff || __WCHAR_MAX__ == 0xffffffff) |
+#define WCHAR_T_IS_UTF32 |
+#elif defined(OS_POSIX) && defined(COMPILER_GCC) && \ |
+ defined(__WCHAR_MAX__) && \ |
+ (__WCHAR_MAX__ == 0x7fff || __WCHAR_MAX__ == 0xffff) |
+// On Posix, we'll detect short wchar_t, but projects aren't guaranteed to |
+// compile in this mode (in particular, Chrome doesn't). This is intended for |
+// other projects using base who manage their own dependencies and make sure |
+// short wchar works for them. |
+#define WCHAR_T_IS_UTF16 |
+#else |
+#error Please add support for your compiler in build/build_config.h |
+#endif |
+ |
+#if defined(OS_ANDROID) |
+// The compiler thinks std::string::const_iterator and "const char*" are |
+// equivalent types. |
+#define STD_STRING_ITERATOR_IS_CHAR_POINTER |
+// The compiler thinks base::string16::const_iterator and "char16*" are |
+// equivalent types. |
+#define BASE_STRING16_ITERATOR_IS_CHAR16_POINTER |
+#endif |
+ |
+#endif // BUILD_BUILD_CONFIG_H_ |