diff options
author | Konstantin Tokarev <annulen@yandex.ru> | 2016-08-25 19:20:41 +0300 |
---|---|---|
committer | Konstantin Tokarev <annulen@yandex.ru> | 2017-02-02 12:30:55 +0000 |
commit | 6882a04fb36642862b11efe514251d32070c3d65 (patch) | |
tree | b7959826000b061fd5ccc7512035c7478742f7b0 /Source/WTF/wtf/Platform.h | |
parent | ab6df191029eeeb0b0f16f127d553265659f739e (diff) |
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f
Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/WTF/wtf/Platform.h')
-rw-r--r-- | Source/WTF/wtf/Platform.h | 859 |
1 files changed, 445 insertions, 414 deletions
diff --git a/Source/WTF/wtf/Platform.h b/Source/WTF/wtf/Platform.h index 562840cf7..2b7a31325 100644 --- a/Source/WTF/wtf/Platform.h +++ b/Source/WTF/wtf/Platform.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2006, 2007, 2008, 2009, 2013 Apple Inc. All rights reserved. + * Copyright (C) 2006-2009, 2013-2015 Apple Inc. All rights reserved. * Copyright (C) 2007-2009 Torch Mobile, Inc. * Copyright (C) 2010, 2011 Research In Motion Limited. All rights reserved. * @@ -12,10 +12,10 @@ * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * - * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR @@ -51,7 +51,7 @@ /* ==== Policy decision macros: these define policy choices for a particular port. ==== */ /* USE() - use a particular third-party library or optional OS service */ -#define USE(WTF_FEATURE) (defined WTF_USE_##WTF_FEATURE && WTF_USE_##WTF_FEATURE) +#define USE(WTF_FEATURE) (defined USE_##WTF_FEATURE && USE_##WTF_FEATURE) /* ENABLE() - turn on a specific feature of WebKit */ #define ENABLE(WTF_FEATURE) (defined ENABLE_##WTF_FEATURE && ENABLE_##WTF_FEATURE) @@ -68,6 +68,7 @@ /* CPU(HPPA) - HP PA-RISC */ #if defined(__hppa__) || defined(__hppa64__) #define WTF_CPU_HPPA 1 +#define WTF_CPU_BIG_ENDIAN 1 #endif /* CPU(IA64) - Itanium / IA-64 */ @@ -79,19 +80,15 @@ #endif #endif -/* CPU(MIPS64) - MIPS 64-bit */ -#if defined(__mips64) +/* CPU(MIPS) - MIPS 32-bit and 64-bit */ +#if (defined(mips) || defined(__mips__) || defined(MIPS) || defined(_MIPS_) || defined(__mips64)) +#if defined(_ABI64) && (_MIPS_SIM == _ABI64) #define WTF_CPU_MIPS64 1 #define WTF_MIPS_ARCH __mips64 -/* CPU(MIPS) - MIPS 32-bit */ -/* Note: Only O32 ABI is tested, so we enable it for O32 ABI for now. */ -#elif (defined(mips) || defined(__mips__) || defined(MIPS) || defined(_MIPS_)) \ - && defined(_ABIO32) +#else #define WTF_CPU_MIPS 1 #define WTF_MIPS_ARCH __mips #endif - -#if CPU(MIPS) || CPU(MIPS64) #if defined(__MIPSEB__) #define WTF_CPU_BIG_ENDIAN 1 #endif @@ -103,55 +100,46 @@ #define WTF_MIPS_DOUBLE_FLOAT (defined __mips_hard_float && !defined __mips_single_float) #define WTF_MIPS_FP64 (defined __mips_fpr && __mips_fpr == 64) /* MIPS requires allocators to use aligned memory */ -#define WTF_USE_ARENA_ALLOC_ALIGNMENT_INTEGER 1 +#define USE_ARENA_ALLOC_ALIGNMENT_INTEGER 1 #endif /* MIPS */ -/* CPU(PPC) - PowerPC 32-bit */ -#if defined(__ppc__) \ - || defined(__PPC__) \ - || defined(__powerpc__) \ - || defined(__powerpc) \ - || defined(__POWERPC__) \ - || defined(_M_PPC) \ - || defined(__PPC) -#define WTF_CPU_PPC 1 -#ifndef __LITTLE_ENDIAN__ +/* CPU(PPC64) - PowerPC 64-bit Big Endian */ +#if ( defined(__ppc64__) \ + || defined(__PPC64__)) \ + && defined(__BYTE_ORDER__) \ + && (__BYTE_ORDER__ == __ORDER_BIG_ENDIAN__) +#define WTF_CPU_PPC64 1 #define WTF_CPU_BIG_ENDIAN 1 #endif + +/* CPU(PPC64) - PowerPC 64-bit Little Endian */ +#if ( defined(__ppc64__) \ + || defined(__PPC64__) \ + || defined(__ppc64le__) \ + || defined(__PPC64LE__)) \ + && defined(__BYTE_ORDER__) \ + && (__BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__) +#define WTF_CPU_PPC64LE 1 #endif -/* CPU(PPC64) - PowerPC 64-bit */ -#if defined(__ppc64__) \ - || defined(__PPC64__) -#define WTF_CPU_PPC64 1 -#ifndef __LITTLE_ENDIAN__ +/* CPU(PPC) - PowerPC 32-bit */ +#if ( defined(__ppc__) \ + || defined(__PPC__) \ + || defined(__powerpc__) \ + || defined(__powerpc) \ + || defined(__POWERPC__) \ + || defined(_M_PPC) \ + || defined(__PPC)) \ + && !CPU(PPC64) \ + && defined(__BYTE_ORDER__) \ + && (__BYTE_ORDER__ == __ORDER_BIG_ENDIAN__) +#define WTF_CPU_PPC 1 #define WTF_CPU_BIG_ENDIAN 1 #endif -#endif /* CPU(SH4) - SuperH SH-4 */ #if defined(__SH4__) #define WTF_CPU_SH4 1 -#ifdef __BIG_ENDIAN__ -#define WTF_CPU_BIG_ENDIAN 1 -#endif -#endif - -/* CPU(SPARC32) - SPARC 32-bit */ -#if defined(__sparc) && !defined(__arch64__) || defined(__sparcv8) -#define WTF_CPU_SPARC32 1 -#define WTF_CPU_BIG_ENDIAN 1 -#endif - -/* CPU(SPARC64) - SPARC 64-bit */ -#if defined(__sparc__) && defined(__arch64__) || defined (__sparcv9) -#define WTF_CPU_SPARC64 1 -#define WTF_CPU_BIG_ENDIAN 1 -#endif - -/* CPU(SPARC) - any SPARC, true for CPU(SPARC32) and CPU(SPARC64) */ -#if CPU(SPARC32) || CPU(SPARC64) -#define WTF_CPU_SPARC 1 #endif /* CPU(S390X) - S390 64-bit */ @@ -161,7 +149,8 @@ #endif /* CPU(S390) - S390 32-bit */ -#if defined(__s390__) +#if ( defined(__s390__) \ + && !CPU(S390X)) #define WTF_CPU_S390 1 #define WTF_CPU_BIG_ENDIAN 1 #endif @@ -179,11 +168,11 @@ #if defined(__x86_64__) \ || defined(_M_X64) #define WTF_CPU_X86_64 1 - -#if defined(__ILP32__) -#define WTF_CPU_X32 1 #endif +/* CPU(ARM64) - Apple */ +#if (defined(__arm64__) && defined(__APPLE__)) || defined(__aarch64__) +#define WTF_CPU_ARM64 1 #endif /* CPU(ARM) - ARM, any version*/ @@ -199,14 +188,13 @@ #define WTF_CPU_ARM_HARDFP 1 #endif -#if defined(__ARMEB__) || (COMPILER(RVCT) && defined(__BIG_ENDIAN)) +#if defined(__ARMEB__) #define WTF_CPU_BIG_ENDIAN 1 #elif !defined(__ARM_EABI__) \ && !defined(__EABI__) \ && !defined(__VFP_FP__) \ - && !defined(_WIN32_WCE) \ - && !defined(ANDROID) + && !defined(_WIN32_WCE) #define WTF_CPU_MIDDLE_ENDIAN 1 #endif @@ -227,7 +215,7 @@ || defined(__ARM_ARCH_5TEJ__) #define WTF_ARM_ARCH_VERSION 5 /*ARMv5TE requires allocators to use aligned memory*/ -#define WTF_USE_ARENA_ALLOC_ALIGNMENT_INTEGER 1 +#define USE_ARENA_ALLOC_ALIGNMENT_INTEGER 1 #elif defined(__ARM_ARCH_6__) \ || defined(__ARM_ARCH_6J__) \ @@ -239,10 +227,14 @@ #define WTF_ARM_ARCH_VERSION 6 #elif defined(__ARM_ARCH_7A__) \ + || defined(__ARM_ARCH_7K__) \ || defined(__ARM_ARCH_7R__) \ || defined(__ARM_ARCH_7S__) #define WTF_ARM_ARCH_VERSION 7 +#elif defined(__ARM_ARCH_8__) +#define WTF_ARM_ARCH_VERSION 8 + /* MSVC sets _M_ARM */ #elif defined(_M_ARM) #define WTF_ARM_ARCH_VERSION _M_ARM @@ -255,7 +247,7 @@ || defined(__TARGET_ARCH_5TE) \ || defined(__TARGET_ARCH_5TEJ) /*ARMv5TE requires allocators to use aligned memory*/ -#define WTF_USE_ARENA_ALLOC_ALIGNMENT_INTEGER 1 +#define USE_ARENA_ALLOC_ALIGNMENT_INTEGER 1 #endif #else @@ -282,6 +274,7 @@ #elif defined(__ARM_ARCH_6T2__) \ || defined(__ARM_ARCH_7__) \ || defined(__ARM_ARCH_7A__) \ + || defined(__ARM_ARCH_7K__) \ || defined(__ARM_ARCH_7M__) \ || defined(__ARM_ARCH_7R__) \ || defined(__ARM_ARCH_7S__) @@ -295,19 +288,15 @@ #define WTF_THUMB_ARCH_VERSION 0 #endif -/* CPU(ARM_FEATURE_UNALIGNED) - ARM instruction set supports unaligned access */ -/* On ARMv5 and below the natural alignment is required. */ -#if !defined(WTF_CPU_ARM_FEATURE_UNALIGNED) -#if COMPILER(GCC) && GCC_VERSION_AT_LEAST(4, 7, 0) -/* Check for feature define in case we are building with -mno-unaligned-access or for ARMv6-M */ -#if defined(__ARM_FEATURE_UNALIGNED) -#define WTF_CPU_ARM_FEATURE_UNALIGNED 1 -#endif -#elif WTF_ARM_ARCH_AT_LEAST(6) -#define WTF_CPU_ARM_FEATURE_UNALIGNED 1 -#endif + +/* CPU(ARMV5_OR_LOWER) - ARM instruction set v5 or earlier */ +/* On ARMv5 and below the natural alignment is required. + And there are some other differences for v5 or earlier. */ +#if !defined(ARMV5_OR_LOWER) && !WTF_ARM_ARCH_AT_LEAST(6) +#define WTF_CPU_ARMV5_OR_LOWER 1 #endif + /* CPU(ARM_TRADITIONAL) - Thumb2 is not available, only traditional ARM (v4 or greater) */ /* CPU(ARM_THUMB2) - Thumb2 instruction set is available */ /* Only one of these will be defined. */ @@ -330,8 +319,8 @@ #define WTF_CPU_ARM_NEON 1 #endif -#if CPU(ARM_NEON) && (!COMPILER(GCC) || GCC_VERSION_AT_LEAST(4, 7, 0)) -// All NEON intrinsics usage can be disabled by this macro. +#if CPU(ARM_NEON) +/* All NEON intrinsics usage can be disabled by this macro. */ #define HAVE_ARM_NEON_INTRINSICS 1 #endif @@ -339,36 +328,27 @@ #define WTF_CPU_ARM_VFP 1 #endif +#if defined(__ARM_ARCH_7K__) +#define WTF_CPU_APPLE_ARMV7K 1 +#endif + #if defined(__ARM_ARCH_7S__) #define WTF_CPU_APPLE_ARMV7S 1 #endif -#endif /* ARM */ - -/* CPU(AARCH64) - AArch64 */ -#if defined(__aarch64__) -#define WTF_CPU_AARCH64 1 -#if defined(__AARCH64EB__) -#define WTF_CPU_BIG_ENDIAN 1 -#endif +#if defined(__ARM_ARCH_EXT_IDIV__) || CPU(APPLE_ARMV7S) +#define HAVE_ARM_IDIV_INSTRUCTIONS 1 #endif -#if CPU(ARM) || CPU(MIPS) || CPU(SH4) || CPU(SPARC) || CPU(MIPS64) +#endif /* ARM */ + +#if CPU(ARM) || CPU(MIPS) || CPU(SH4) #define WTF_CPU_NEEDS_ALIGNED_ACCESS 1 #endif /* ==== OS() - underlying operating system; only to be used for mandated low-level services like virtual memory, not to choose a GUI toolkit ==== */ -/* OS(ANDROID) - Android */ -#ifdef ANDROID -#define WTF_OS_ANDROID 1 -#endif - -#if OS(ANDROID) && !defined(Q_OS_ANDROID_NO_SDK) -#define WTF_HAVE_ANDROID_SDK 1 -#endif - /* OS(AIX) - AIX */ #ifdef _AIX #define WTF_OS_AIX 1 @@ -391,19 +371,6 @@ #define WTF_OS_IOS 1 #elif OS(DARWIN) && defined(TARGET_OS_MAC) && TARGET_OS_MAC #define WTF_OS_MAC_OS_X 1 - -/* FIXME: These can be removed after sufficient time has passed since the removal of BUILDING_ON / TARGETING macros. */ - -#define ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MIN_REQUIRED 0 / 0 -#define ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MAX_ALLOWED 0 / 0 - -#define BUILDING_ON_LEOPARD ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MIN_REQUIRED -#define BUILDING_ON_SNOW_LEOPARD ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MIN_REQUIRED -#define BUILDING_ON_LION ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MIN_REQUIRED - -#define TARGETING_LEOPARD ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MAX_ALLOWED -#define TARGETING_SNOW_LEOPARD ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MAX_ALLOWED -#define TARGETING_LION ERROR_PLEASE_COMPARE_WITH_MAC_OS_X_VERSION_MAX_ALLOWED #endif /* OS(FREEBSD) - FreeBSD */ @@ -431,21 +398,11 @@ #define WTF_OS_OPENBSD 1 #endif -/* OS(QNX) - QNX */ -#if defined(__QNXNTO__) -#define WTF_OS_QNX 1 -#endif - /* OS(SOLARIS) - Solaris */ #if defined(sun) || defined(__sun) #define WTF_OS_SOLARIS 1 #endif -/* OS(WINCE) - Windows CE; note that for this platform OS(WINDOWS) is also defined */ -#if defined(_WIN32_WCE) -#define WTF_OS_WINCE 1 -#endif - /* OS(WINDOWS) - Any version of Windows */ #if defined(WIN32) || defined(_WIN32) #define WTF_OS_WINDOWS 1 @@ -455,15 +412,13 @@ #define WTF_OS_MAC ERROR "USE MAC_OS_X WITH OS NOT MAC" /* OS(UNIX) - Any Unix-like system */ -#if OS(AIX) \ - || OS(ANDROID) \ +#if OS(AIX) \ || OS(DARWIN) \ || OS(FREEBSD) \ || OS(HURD) \ || OS(LINUX) \ || OS(NETBSD) \ || OS(OPENBSD) \ - || OS(QNX) \ || OS(SOLARIS) \ || defined(unix) \ || defined(__unix) \ @@ -471,41 +426,21 @@ #define WTF_OS_UNIX 1 #endif -#if OS(WINDOWS) -// Minimum supported windows is Windows XP. -// The original WinXP was NT 5.1, but Win XP 64bit was NT 5.2 -#if CPU(X86_64) -#ifndef _WIN32_WINNT -#define _WIN32_WINNT 0x0502 -#endif - -#ifndef WINVER -#define WINVER 0x0502 -#endif - -#else /* !CPU(X86_64) */ - -#ifndef _WIN32_WINNT -#define _WIN32_WINNT 0x0501 -#endif - -#ifndef WINVER -#define WINVER 0x0501 -#endif - -#endif +/* Operating environments */ +/* Standard libraries */ +#if defined(HAVE_FEATURES_H) && HAVE_FEATURES_H +/* If the included features.h is glibc's one, __GLIBC__ is defined. */ +#include <features.h> #endif - -/* Operating environments */ - /* FIXME: these are all mixes of OS, operating environment and policy choices. */ /* PLATFORM(QT) */ /* PLATFORM(EFL) */ /* PLATFORM(GTK) */ -/* PLATFORM(BLACKBERRY) */ /* PLATFORM(MAC) */ +/* PLATFORM(IOS) */ +/* PLATFORM(IOS_SIMULATOR) */ /* PLATFORM(WIN) */ #if defined(BUILDING_QT__) #define WTF_PLATFORM_QT 1 @@ -513,155 +448,176 @@ #define WTF_PLATFORM_EFL 1 #elif defined(BUILDING_GTK__) #define WTF_PLATFORM_GTK 1 -#elif defined(BUILDING_BLACKBERRY__) -#define WTF_PLATFORM_BLACKBERRY 1 -#elif OS(DARWIN) +#elif OS(MAC_OS_X) #define WTF_PLATFORM_MAC 1 +#elif OS(IOS) +#define WTF_PLATFORM_IOS 1 +#if defined(TARGET_IPHONE_SIMULATOR) && TARGET_IPHONE_SIMULATOR +#define WTF_PLATFORM_IOS_SIMULATOR 1 +#endif #elif OS(WINDOWS) #define WTF_PLATFORM_WIN 1 #endif -/* PLATFORM(IOS) */ -/* FIXME: this is sometimes used as an OS switch and sometimes for higher-level things */ -#if (defined(TARGET_OS_EMBEDDED) && TARGET_OS_EMBEDDED) || (defined(TARGET_OS_IPHONE) && TARGET_OS_IPHONE) -#define WTF_PLATFORM_IOS 1 +/* PLATFORM(COCOA) */ +#if PLATFORM(MAC) || PLATFORM(IOS) +#define WTF_PLATFORM_COCOA 1 #endif -/* PLATFORM(IOS_SIMULATOR) */ -#if defined(TARGET_IPHONE_SIMULATOR) && TARGET_IPHONE_SIMULATOR -#define WTF_PLATFORM_IOS 1 -#define WTF_PLATFORM_IOS_SIMULATOR 1 +#if PLATFORM(COCOA) +#if defined __has_include && __has_include(<CoreFoundation/CFPriv.h>) +#define USE_APPLE_INTERNAL_SDK 1 +#endif +#endif + +/* PLATFORM(APPLETV) */ +#if defined(TARGET_OS_TV) && TARGET_OS_TV +#define WTF_PLATFORM_APPLETV 1 +#endif + +/* PLATFORM(WATCHOS) */ +#if defined(TARGET_OS_WATCH) && TARGET_OS_WATCH +#define WTF_PLATFORM_WATCHOS 1 #endif /* Graphics engines */ /* USE(CG) and PLATFORM(CI) */ -#if PLATFORM(MAC) || PLATFORM(IOS) || (PLATFORM(WIN) && !USE(WINGDI) && !PLATFORM(WIN_CAIRO)) -#define WTF_USE_CG 1 +#if PLATFORM(COCOA) || (PLATFORM(WIN) && !USE(WINGDI) && !PLATFORM(WIN_CAIRO)) +#define USE_CG 1 #endif -#if PLATFORM(MAC) || PLATFORM(IOS) || (PLATFORM(WIN) && USE(CG)) -#define WTF_USE_CA 1 +#if PLATFORM(COCOA) || (PLATFORM(WIN) && USE(CG)) +#define USE_CA 1 #endif -#if PLATFORM(BLACKBERRY) -#define WTF_USE_LOW_QUALITY_IMAGE_INTERPOLATION 1 -#define WTF_USE_LOW_QUALITY_IMAGE_NO_JPEG_DITHERING 1 -#define WTF_USE_LOW_QUALITY_IMAGE_NO_JPEG_FANCY_UPSAMPLING 1 +#if PLATFORM(GTK) || PLATFORM(EFL) +#define USE_CAIRO 1 +#define USE_GLIB 1 +#define USE_FREETYPE 1 +#define USE_HARFBUZZ 1 +#define USE_SOUP 1 +#define USE_WEBP 1 #endif -#if PLATFORM(GTK) -#define WTF_USE_CAIRO 1 -#define WTF_USE_GLIB 1 -#define WTF_USE_FREETYPE 1 -#define WTF_USE_HARFBUZZ 1 -#define WTF_USE_SOUP 1 -#define WTF_USE_WEBP 1 -#define ENABLE_GLOBAL_FASTMALLOC_NEW 0 -#define GST_API_VERSION_1 1 +#if PLATFORM(EFL) +#define GLIB_VERSION_MIN_REQUIRED GLIB_VERSION_2_38 +#elif PLATFORM(GTK) +#define GLIB_VERSION_MIN_REQUIRED GLIB_VERSION_2_36 #endif -/* On Windows, use QueryPerformanceCounter by default */ -#if OS(WINDOWS) -#define WTF_USE_QUERY_PERFORMANCE_COUNTER 1 +#if PLATFORM(GTK) && !defined(GTK_API_VERSION_2) +#define GDK_VERSION_MIN_REQUIRED GDK_VERSION_3_6 #endif -#if OS(WINCE) && !PLATFORM(QT) -#define NOSHLWAPI /* shlwapi.h not available on WinCe */ +#if USE(SOUP) +#define SOUP_VERSION_MIN_REQUIRED SOUP_VERSION_2_42 +#endif -/* MSDN documentation says these functions are provided with uspce.lib. But we cannot find this file. */ -#define __usp10__ /* disable "usp10.h" */ +/* On Windows, use QueryPerformanceCounter by default */ +#if OS(WINDOWS) +#define USE_QUERY_PERFORMANCE_COUNTER 1 +#endif -#define _INC_ASSERT /* disable "assert.h" */ -#define assert(x) +#if PLATFORM(COCOA) -#endif /* OS(WINCE) && !PLATFORM(QT) */ +#define USE_CF 1 +#define USE_FOUNDATION 1 +#define USE_NETWORK_CFDATA_ARRAY_CALLBACK 1 +#define ENABLE_USER_MESSAGE_HANDLERS 1 +#define HAVE_OUT_OF_PROCESS_LAYER_HOSTING 1 +#define HAVE_DTRACE 1 -#if OS(ANDROID) && PLATFORM(QT) -# define WTF_USE_WCHAR_UNICODE 1 +#if !PLATFORM(WATCHOS) && !PLATFORM(APPLETV) +#define HAVE_AVKIT 1 +#define HAVE_PARENTAL_CONTROLS 1 #endif -#if !USE(WCHAR_UNICODE) -#define WTF_USE_ICU_UNICODE 1 #endif -#if PLATFORM(MAC) && !PLATFORM(IOS) +#if PLATFORM(MAC) + +#define USE_APPKIT 1 +#define HAVE_RUNLOOP_TIMER 1 +#define HAVE_SEC_IDENTITY 1 +#define HAVE_SEC_KEYCHAIN 1 + #if CPU(X86_64) -#define WTF_USE_PLUGIN_HOST_PROCESS 1 -#endif -#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070 -#define WTF_USE_SCROLLBAR_PAINTER 1 -#define HAVE_XPC 1 +#define HAVE_NETWORK_EXTENSION 1 +#define USE_PLUGIN_HOST_PROCESS 1 #endif -#define WTF_USE_CF 1 + +/* OS X defines a series of platform macros for debugging. */ +/* Some of them are really annoying because they use common names (e.g. check()). */ +/* Disable those macros so that we are not limited in how we name methods and functions. */ +#undef __ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORES +#define __ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORES 0 + +#endif /* PLATFORM(MAC) */ + +#if PLATFORM(IOS) + +#define HAVE_NETWORK_EXTENSION 1 #define HAVE_READLINE 1 -#define HAVE_RUNLOOP_TIMER 1 -#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1080 -#define HAVE_LAYER_HOSTING_IN_WINDOW_SERVER 1 +#if USE(APPLE_INTERNAL_SDK) +#define USE_CFNETWORK 1 #endif -#define WTF_USE_APPKIT 1 -#define WTF_USE_SECURITY_FRAMEWORK 1 -#endif /* PLATFORM(MAC) && !PLATFORM(IOS) */ +#define USE_UIKIT_EDITING 1 +#define USE_WEB_THREAD 1 -#if PLATFORM(IOS) -#define DONT_FINALIZE_ON_MAIN_THREAD 1 +#if !PLATFORM(WATCHOS) && !PLATFORM(APPLETV) +#define USE_QUICK_LOOK 1 #endif -#if PLATFORM(QT) && OS(DARWIN) -#define WTF_USE_CF 1 +#if TARGET_OS_IOS +#define HAVE_APP_LINKS 1 #endif -#if OS(DARWIN) && !PLATFORM(GTK) && !PLATFORM(QT) -#define ENABLE_PURGEABLE_MEMORY 1 +#if CPU(ARM64) +#define ENABLE_JIT_CONSTANT_BLINDING 0 +#endif + +#if CPU(ARM_NEON) +#undef HAVE_ARM_NEON_INTRINSICS +#define HAVE_ARM_NEON_INTRINSICS 0 #endif -#if PLATFORM(IOS) -#define HAVE_READLINE 1 -#define WTF_USE_APPKIT 0 -#define WTF_USE_CF 1 -#define WTF_USE_CFNETWORK 1 -#define WTF_USE_NETWORK_CFDATA_ARRAY_CALLBACK 1 -#define WTF_USE_SECURITY_FRAMEWORK 0 -#define WTF_USE_WEB_THREAD 1 #endif /* PLATFORM(IOS) */ #if PLATFORM(WIN) && !USE(WINGDI) -#define WTF_USE_CF 1 +#define USE_CF 1 #endif #if PLATFORM(WIN) && !USE(WINGDI) && !PLATFORM(WIN_CAIRO) -#define WTF_USE_CFNETWORK 1 +#define USE_CFNETWORK 1 #endif -#if USE(CFNETWORK) || PLATFORM(MAC) || PLATFORM(IOS) -#define WTF_USE_CFURLCACHE 1 +#if USE(CFNETWORK) || PLATFORM(COCOA) +#define USE_CFURLCACHE 1 #endif #if !defined(HAVE_ACCESSIBILITY) -#if PLATFORM(IOS) || PLATFORM(MAC) || PLATFORM(WIN) || PLATFORM(GTK) || PLATFORM(EFL) +#if PLATFORM(COCOA) || PLATFORM(WIN) || PLATFORM(GTK) || PLATFORM(EFL) #define HAVE_ACCESSIBILITY 1 #endif #endif /* !defined(HAVE_ACCESSIBILITY) */ #if OS(UNIX) #define HAVE_ERRNO_H 1 -#define HAVE_MMAP 1 +#define HAVE_LANGINFO_H 1 +#define HAVE_MMAP 1 #define HAVE_SIGNAL_H 1 #define HAVE_STRINGS_H 1 #define HAVE_SYS_PARAM_H 1 #define HAVE_SYS_TIME_H 1 -#define WTF_USE_PTHREADS 1 +#define USE_PTHREADS 1 #endif /* OS(UNIX) */ -#if OS(UNIX) && !OS(ANDROID) && !OS(QNX) -#define HAVE_LANGINFO_H 1 -#endif - #if (OS(FREEBSD) || OS(OPENBSD)) && !defined(__GLIBC__) #define HAVE_PTHREAD_NP_H 1 #endif #if !defined(HAVE_VASPRINTF) -#if !COMPILER(MSVC) && !COMPILER(RVCT) && !COMPILER(MINGW) && !(COMPILER(GCC) && OS(QNX)) +#if !COMPILER(MSVC) && !COMPILER(MINGW) #define HAVE_VASPRINTF 1 #endif #endif @@ -672,7 +628,11 @@ #endif #endif -#if !OS(WINDOWS) && !OS(SOLARIS) && !OS(ANDROID) +#if (OS(DARWIN) || OS(FREEBSD) || OS(NETBSD)) && !defined(__GLIBC__) +#define HAVE_STAT_BIRTHTIME 1 +#endif + +#if !OS(WINDOWS) && !OS(SOLARIS) #define HAVE_TM_GMTOFF 1 #define HAVE_TM_ZONE 1 #define HAVE_TIMEGM 1 @@ -683,26 +643,27 @@ #define HAVE_DISPATCH_H 1 #define HAVE_MADV_FREE 1 #define HAVE_MADV_FREE_REUSE 1 +#define HAVE_MADV_DONTNEED 1 #define HAVE_MERGESORT 1 #define HAVE_PTHREAD_SETNAME_NP 1 +#define HAVE_READLINE 1 #define HAVE_SYS_TIMEB_H 1 -#define WTF_USE_ACCELERATE 1 +#if !PLATFORM(GTK) && !PLATFORM(QT) +#define USE_ACCELERATE 1 +#endif #if !PLATFORM(IOS) #define HAVE_HOSTED_CORE_ANIMATION 1 -#endif /* !PLATFORM(IOS) */ +#endif #endif /* OS(DARWIN) */ -#if OS(WINDOWS) && !OS(WINCE) +#if OS(WINDOWS) + #define HAVE_SYS_TIMEB_H 1 #define HAVE_ALIGNED_MALLOC 1 #define HAVE_ISDEBUGGERPRESENT 1 -#if !PLATFORM(QT) -#include <WTF/WTFHeaderDetection.h> -#endif - #endif #if OS(WINDOWS) @@ -716,25 +677,9 @@ /* Include feature macros */ #include <wtf/FeatureDefines.h> -#if PLATFORM(QT) -/* We must not customize the global operator new and delete for the Qt port. */ -#define ENABLE_GLOBAL_FASTMALLOC_NEW 0 -#if !OS(UNIX) +#if OS(WINDOWS) && !PLATFORM(QT) #define USE_SYSTEM_MALLOC 1 #endif -#endif - -#if PLATFORM(EFL) -#define ENABLE_GLOBAL_FASTMALLOC_NEW 0 -#endif - -#if OS(WINDOWS) -#define ENABLE_GLOBAL_FASTMALLOC_NEW 0 -#endif - -#if !defined(ENABLE_GLOBAL_FASTMALLOC_NEW) -#define ENABLE_GLOBAL_FASTMALLOC_NEW 1 -#endif #define ENABLE_DEBUG_WITH_BREAKPOINT 0 #define ENABLE_SAMPLING_COUNTERS 0 @@ -749,92 +694,71 @@ #define ENABLE_SAMPLING_THREAD 1 #endif -#if !defined(WTF_USE_JSVALUE64) && !defined(WTF_USE_JSVALUE32_64) -#if (CPU(X86_64) && (OS(UNIX) || OS(WINDOWS)) && !CPU(X32)) \ +#if !defined(USE_JSVALUE64) && !defined(USE_JSVALUE32_64) +#if (CPU(X86_64) && (OS(UNIX) || OS(WINDOWS))) \ || (CPU(IA64) && !CPU(IA64_32)) \ || CPU(ALPHA) \ - || CPU(SPARC64) \ + || CPU(ARM64) \ || CPU(S390X) \ - || CPU(AARCH64) \ || CPU(MIPS64) \ - || CPU(PPC64) -#define WTF_USE_JSVALUE64 1 + || CPU(PPC64) \ + || CPU(PPC64LE) +#define USE_JSVALUE64 1 #else -#define WTF_USE_JSVALUE32_64 1 -#endif -#endif /* !defined(WTF_USE_JSVALUE64) && !defined(WTF_USE_JSVALUE32_64) */ - -/* Disable the JIT on versions of GCC prior to 4.1 */ -#if !defined(ENABLE_JIT) && COMPILER(GCC) && !GCC_VERSION_AT_LEAST(4, 1, 0) -#define ENABLE_JIT 0 +#define USE_JSVALUE32_64 1 #endif +#endif /* !defined(USE_JSVALUE64) && !defined(USE_JSVALUE32_64) */ -/* All the current JIT implementations target little-endian */ -#if CPU(BIG_ENDIAN) -#define ENABLE_JIT 0 -#endif - -/* Disable JIT on x32 */ -#if CPU(X32) -#define ENABLE_JIT 0 +/* The JIT is enabled by default on all x86, x86-64, ARM & MIPS platforms except ARMv7k. */ +#if !defined(ENABLE_JIT) \ + && (CPU(X86) || CPU(X86_64) || CPU(ARM) || CPU(ARM64) || CPU(MIPS)) \ + && !CPU(APPLE_ARMV7K) +#define ENABLE_JIT 1 #endif -#if !defined(ENABLE_JIT) && CPU(SH4) && PLATFORM(QT) -#define ENABLE_JIT 1 +/* The FTL *does not* work on 32-bit platforms. Disable it even if someone asked us to enable it. */ +#if USE(JSVALUE32_64) +#undef ENABLE_FTL_JIT +#define ENABLE_FTL_JIT 0 #endif -/* The JIT is enabled by default on all x86, x86-64, ARM & MIPS platforms. */ -#if !defined(ENABLE_JIT) \ - && (CPU(X86) || CPU(X86_64) || CPU(ARM) || CPU(MIPS)) \ - && (OS(DARWIN) || !COMPILER(GCC) || GCC_VERSION_AT_LEAST(4, 1, 0)) \ - && !OS(WINCE) \ - && !(OS(QNX) && !PLATFORM(QT)) /* We use JIT in QNX Qt */ -#define ENABLE_JIT 1 +/* The FTL is disabled on the iOS simulator, mostly for simplicity. */ +#if PLATFORM(IOS_SIMULATOR) +#undef ENABLE_FTL_JIT +#define ENABLE_FTL_JIT 0 #endif /* If possible, try to enable a disassembler. This is optional. We proceed in two steps: first we try to find some disassembler that we can use, and then we decide if the high-level disassembler API can be enabled. */ -#if !defined(WTF_USE_UDIS86) && ENABLE(JIT) && (PLATFORM(MAC) || (PLATFORM(QT) && OS(LINUX))) \ +#if !defined(USE_UDIS86) && ENABLE(JIT) && ((OS(DARWIN) && !PLATFORM(EFL) && !PLATFORM(GTK)) || (OS(LINUX) && (PLATFORM(EFL) || PLATFORM(GTK) || PLATFORM(QT)))) \ && (CPU(X86) || CPU(X86_64)) -#define WTF_USE_UDIS86 1 +#define USE_UDIS86 1 #endif -#if !defined(WTF_USE_ARMV7_DISASSEMBLER) && ENABLE(JIT) && PLATFORM(IOS) && CPU(ARM_THUMB2) -#define WTF_USE_ARMV7_DISASSEMBLER 1 -#endif - -#if !defined(ENABLE_DISASSEMBLER) && (USE(UDIS86) || USE(ARMV7_DISASSEMBLER)) +#if !defined(ENABLE_DISASSEMBLER) && USE(UDIS86) #define ENABLE_DISASSEMBLER 1 #endif -/* Disable the LLINT on versions of GCC prior to 4.3. Mainly due to buggy assembler on OSX 10.6, the only supported platform using that old a version. */ -#if !defined(ENABLE_LLINT) && COMPILER(GCC) && !GCC_VERSION_AT_LEAST(4, 3, 0) -#define ENABLE_LLINT 0 +#if !defined(USE_ARM64_DISASSEMBLER) && ENABLE(JIT) && CPU(ARM64) +#define USE_ARM64_DISASSEMBLER 1 #endif -/* LLINT on ARM depends on an FPU */ -#if !defined(ENABLE_LLINT) && CPU(ARM) && (!CPU(ARM_VFP) || OS(ANDROID)) -#define ENABLE_LLINT 0 +#if !defined(USE_ARMV7_DISASSEMBLER) && ENABLE(JIT) && CPU(ARM_THUMB2) +#define USE_ARMV7_DISASSEMBLER 1 #endif -/* On some of the platforms where we have a JIT, we want to also have the - low-level interpreter. */ -#if !defined(ENABLE_LLINT) \ - && ENABLE(JIT) \ - && (OS(DARWIN) || OS(LINUX)) \ - && (PLATFORM(MAC) || PLATFORM(IOS) || PLATFORM(GTK) || PLATFORM(QT)) \ - && (CPU(X86) || CPU(X86_64) || CPU(ARM_THUMB2) || CPU(ARM_TRADITIONAL) || CPU(MIPS) || CPU(SH4)) -#define ENABLE_LLINT 1 +#if !defined(ENABLE_DISASSEMBLER) && (USE(UDIS86) || USE(ARMV7_DISASSEMBLER) || USE(ARM64_DISASSEMBLER)) +#define ENABLE_DISASSEMBLER 1 #endif -#if !defined(ENABLE_DFG_JIT) && ENABLE(JIT) && !COMPILER(MSVC) -/* Enable the DFG JIT on X86 and X86_64. Only tested on Mac and GNU/Linux. */ -#if (CPU(X86) || CPU(X86_64)) && (OS(DARWIN) || OS(LINUX)) +#if !defined(ENABLE_DFG_JIT) && ENABLE(JIT) +/* Enable the DFG JIT on X86 and X86_64. */ +#if (CPU(X86) || CPU(X86_64)) && (OS(DARWIN) || OS(LINUX) || OS(FREEBSD) || OS(WINDOWS) || OS(HURD)) #define ENABLE_DFG_JIT 1 #endif -/* Enable the DFG JIT on ARMv7. Only tested on iOS and Qt Linux. */ -#if CPU(ARM_THUMB2) && (PLATFORM(IOS) || PLATFORM(BLACKBERRY) || PLATFORM(QT)) +/* Enable the DFG JIT on ARMv7. Only tested on iOS and Qt/GTK+ Linux. */ +#if (CPU(ARM_THUMB2) || CPU(ARM64)) && (PLATFORM(IOS) || PLATFORM(GTK) || PLATFORM(EFL) || PLATFORM(QT)) #define ENABLE_DFG_JIT 1 #endif /* Enable the DFG JIT on ARM, MIPS and SH4. */ @@ -843,36 +767,39 @@ #endif #endif -/* If the jit is not available, enable the LLInt C Loop: */ -#if !ENABLE(JIT) -#undef ENABLE_LLINT /* Undef so that we can redefine it. */ -#undef ENABLE_LLINT_C_LOOP /* Undef so that we can redefine it. */ -#undef ENABLE_DFG_JIT /* Undef so that we can redefine it. */ -#define ENABLE_LLINT 1 -#define ENABLE_LLINT_C_LOOP 1 -#define ENABLE_DFG_JIT 0 +/* Concurrent JIT only works on 64-bit platforms because it requires that + values get stored to atomically. This is trivially true on 64-bit platforms, + but not true at all on 32-bit platforms where values are composed of two + separate sub-values. */ +#if ENABLE(DFG_JIT) && USE(JSVALUE64) +#define ENABLE_CONCURRENT_JIT 1 #endif -/* Do a sanity check to make sure that we at least have one execution engine in - use: */ -#if !(ENABLE(JIT) || ENABLE(LLINT)) -#error You have to have at least one execution model enabled to build JSC +/* This controls whether B3 is built. It will not be used unless FTL_USES_B3 is enabled. */ +#if ENABLE(FTL_JIT) +#define ENABLE_B3_JIT 1 #endif -/* Profiling of types and values used by JIT code. DFG_JIT depends on it, but you - can enable it manually with DFG turned off if you want to use it as a standalone - profiler. In that case, you probably want to also enable VERBOSE_VALUE_PROFILE - below. */ -#if !defined(ENABLE_VALUE_PROFILER) && ENABLE(DFG_JIT) -#define ENABLE_VALUE_PROFILER 1 +/* If the baseline jit is not available, then disable upper tiers as well: */ +#if !ENABLE(JIT) +#undef ENABLE_DFG_JIT +#undef ENABLE_FTL_JIT +#undef ENABLE_B3_JIT +#define ENABLE_DFG_JIT 0 +#define ENABLE_FTL_JIT 0 +#define ENABLE_B3_JIT 0 #endif -#if !defined(ENABLE_VERBOSE_VALUE_PROFILE) && ENABLE(VALUE_PROFILER) -#define ENABLE_VERBOSE_VALUE_PROFILE 0 +/* The SamplingProfiler is the probabilistic and low-overhead profiler used by + * JSC to measure where time is spent inside a JavaScript program. + * In configurations other than Windows and Darwin, because layout of mcontext_t depends on standard libraries (like glibc), + * sampling profiler is enabled if WebKit uses pthreads and glibc. */ +#if !defined(ENABLE_SAMPLING_PROFILER) +#if (OS(DARWIN) || OS(WINDOWS) || PLATFORM(GTK) || PLATFORM(EFL)) && ENABLE(JIT) +#define ENABLE_SAMPLING_PROFILER 1 +#else +#define ENABLE_SAMPLING_PROFILER 0 #endif - -#if !defined(ENABLE_SIMPLE_HEAP_PROFILING) -#define ENABLE_SIMPLE_HEAP_PROFILING 0 #endif /* Counts uses of write barriers using sampling counters. Be sure to also @@ -881,6 +808,16 @@ #define ENABLE_WRITE_BARRIER_PROFILING 0 #endif +/* Logs all allocation-related activity that goes through fastMalloc or the + JSC GC (both cells and butterflies). Also logs marking. Note that this + isn't a completely accurate view of the heap since it doesn't include all + butterfly resize operations, doesn't tell you what is going on with weak + references (other than to tell you when they're marked), and doesn't + track direct mmap() allocations or things like JIT allocation. */ +#if !defined(ENABLE_ALLOCATION_LOGGING) +#define ENABLE_ALLOCATION_LOGGING 0 +#endif + /* Enable verification that that register allocations are not made within generated control flow. Turned on for debug builds. */ #if !defined(ENABLE_DFG_REGISTER_ALLOCATION_VALIDATION) && ENABLE(DFG_JIT) @@ -894,19 +831,19 @@ /* Configure the JIT */ #if CPU(X86) && COMPILER(MSVC) #define JSC_HOST_CALL __fastcall -#elif CPU(X86) && COMPILER(GCC) +#elif CPU(X86) && COMPILER(GCC_OR_CLANG) #define JSC_HOST_CALL __attribute__ ((fastcall)) #else #define JSC_HOST_CALL #endif /* Configure the interpreter */ -#if COMPILER(GCC) || (COMPILER(RVCT) && defined(__GNUC__)) +#if COMPILER(GCC_OR_CLANG) #define HAVE_COMPUTED_GOTO 1 #endif /* Determine if we need to enable Computed Goto Opcodes or not: */ -#if HAVE(COMPUTED_GOTO) && ENABLE(LLINT) +#if HAVE(COMPUTED_GOTO) || ENABLE(JIT) #define ENABLE_COMPUTED_GOTO_OPCODES 1 #endif @@ -914,7 +851,7 @@ #define ENABLE_REGEXP_TRACING 0 /* Yet Another Regex Runtime - turned on by default for JIT enabled ports. */ -#if !defined(ENABLE_YARR_JIT) && !ENABLE(LLINT_C_LOOP) && !(OS(QNX) && PLATFORM(QT)) +#if !defined(ENABLE_YARR_JIT) && ENABLE(JIT) #define ENABLE_YARR_JIT 1 /* Setting this flag compares JIT results with interpreter results. */ @@ -932,64 +869,84 @@ #endif #endif +/* If the Disassembler is enabled, then the Assembler must be enabled as well: */ +#if ENABLE(DISASSEMBLER) +#if defined(ENABLE_ASSEMBLER) && !ENABLE_ASSEMBLER +#error "Cannot enable the Disassembler without enabling the Assembler" +#else +#undef ENABLE_ASSEMBLER +#define ENABLE_ASSEMBLER 1 +#endif +#endif + +/* Enable the following if you want to use the MacroAssembler::probe() facility + to do JIT debugging. */ +#if (CPU(X86) || CPU(X86_64) || CPU(ARM64) || (CPU(ARM_THUMB2) && PLATFORM(IOS))) && ENABLE(JIT) && OS(DARWIN) && !defined(NDEBUG) +#define ENABLE_MASM_PROBE 1 +#else +#define ENABLE_MASM_PROBE 0 +#endif + /* Pick which allocator to use; we only need an executable allocator if the assembler is compiled in. - On x86-64 we use a single fixed mmap, on other platforms we mmap on demand. */ + On non-Windows x86-64, iOS, and ARM64 we use a single fixed mmap, on other platforms we mmap on demand. */ #if ENABLE(ASSEMBLER) -#if CPU(X86_64) || PLATFORM(IOS) || CPU(MIPS) +#if CPU(X86_64) || PLATFORM(IOS) || CPU(ARM64) #define ENABLE_EXECUTABLE_ALLOCATOR_FIXED 1 #else #define ENABLE_EXECUTABLE_ALLOCATOR_DEMAND 1 #endif #endif -/* Use the QXmlStreamReader implementation for XMLDocumentParser */ -/* Use the QXmlQuery implementation for XSLTProcessor */ -#if PLATFORM(QT) -#if !USE(LIBXML2) -#define WTF_USE_QXMLSTREAM 1 -#define WTF_USE_QXMLQUERY 1 +/* CSS Selector JIT Compiler */ +#if !defined(ENABLE_CSS_SELECTOR_JIT) +#if (CPU(X86_64) || CPU(ARM64) || (CPU(ARM_THUMB2) && PLATFORM(IOS))) && ENABLE(JIT) && (OS(DARWIN) || PLATFORM(GTK) || PLATFORM(EFL) || PLATFORM(QT)) +#define ENABLE_CSS_SELECTOR_JIT 1 +#else +#define ENABLE_CSS_SELECTOR_JIT 0 #endif #endif -/* Accelerated compositing */ -#if PLATFORM(MAC) || PLATFORM(IOS) || PLATFORM(QT) || (PLATFORM(WIN) && !USE(WINGDI) && !PLATFORM(WIN_CAIRO)) -#define WTF_USE_ACCELERATED_COMPOSITING 1 +#if ENABLE(WEBGL) && PLATFORM(WIN) +#define USE_OPENGL 1 +#define USE_OPENGL_ES_2 1 +#define USE_EGL 1 #endif -#if ENABLE(WEBGL) && !defined(WTF_USE_3D_GRAPHICS) -#define WTF_USE_3D_GRAPHICS 1 +#if ENABLE(VIDEO) && PLATFORM(WIN_CAIRO) +#if ENABLE(GSTREAMER_WINCAIRO) +#define USE_MEDIA_FOUNDATION 0 +#define USE_GLIB 1 +#define USE_GSTREAMER 1 +#else +#define USE_MEDIA_FOUNDATION 1 +#endif #endif -/* Qt always uses Texture Mapper */ -#if PLATFORM(QT) -#define WTF_USE_TEXTURE_MAPPER 1 +#if PLATFORM(WIN_CAIRO) || PLATFORM(QT) +#define USE_TEXTURE_MAPPER 1 #endif -#if USE(TEXTURE_MAPPER) && USE(3D_GRAPHICS) && !defined(WTF_USE_TEXTURE_MAPPER_GL) -#define WTF_USE_TEXTURE_MAPPER_GL 1 +#if USE(TEXTURE_MAPPER) && ENABLE(GRAPHICS_CONTEXT_3D) && !defined(USE_TEXTURE_MAPPER_GL) +#define USE_TEXTURE_MAPPER_GL 1 #endif /* Compositing on the UI-process in WebKit2 */ #if USE(3D_GRAPHICS) && PLATFORM(QT) -#define WTF_USE_COORDINATED_GRAPHICS 1 +#define USE_COORDINATED_GRAPHICS 1 #endif -#if PLATFORM(MAC) || PLATFORM(IOS) -#define WTF_USE_PROTECTION_SPACE_AUTH_CALLBACK 1 +#if PLATFORM(COCOA) +#define USE_PROTECTION_SPACE_AUTH_CALLBACK 1 #endif /* Set up a define for a common error that is intended to cause a build error -- thus the space after Error. */ #define WTF_PLATFORM_CFNETWORK Error USE_macro_should_be_used_with_CFNETWORK -#if PLATFORM(WIN) -#define WTF_USE_CROSS_PLATFORM_CONTEXT_MENUS 1 +#if PLATFORM(COCOA) && HAVE(ACCESSIBILITY) +#define USE_ACCESSIBILITY_CONTEXT_MENUS 1 #endif -#if PLATFORM(MAC) && HAVE(ACCESSIBILITY) -#define WTF_USE_ACCESSIBILITY_CONTEXT_MENUS 1 -#endif - -#if CPU(ARM_THUMB2) +#if CPU(ARM_THUMB2) || CPU(ARM64) #define ENABLE_BRANCH_COMPACTION 1 #endif @@ -1002,37 +959,31 @@ #endif #if USE(GLIB) -#include <wtf/gobject/GTypedefs.h> +#include <wtf/glib/GTypedefs.h> +#endif + +#if PLATFORM(EFL) +#include <wtf/efl/EflTypedefs.h> #endif /* FIXME: This define won't be needed once #27551 is fully landed. However, since most ports try to support sub-project independence, adding new headers to WTF causes many ports to break, and so this way we can address the build breakages one port at a time. */ -#if !defined(WTF_USE_EXPORT_MACROS) && (PLATFORM(MAC) || PLATFORM(QT) || (PLATFORM(WIN) && (defined(_MSC_VER) && _MSC_VER >= 1600))) -#define WTF_USE_EXPORT_MACROS 1 -#endif - -#if !defined(WTF_USE_EXPORT_MACROS_FOR_TESTING) && (PLATFORM(GTK) || PLATFORM(WIN)) -#define WTF_USE_EXPORT_MACROS_FOR_TESTING 1 +#if !defined(USE_EXPORT_MACROS) && (PLATFORM(COCOA) || PLATFORM(QT) || PLATFORM(WIN)) +#define USE_EXPORT_MACROS 1 #endif -#if (PLATFORM(QT) && !OS(DARWIN) && !OS(WINDOWS)) || PLATFORM(GTK) || PLATFORM(EFL) -#define WTF_USE_UNIX_DOMAIN_SOCKETS 1 +#if !defined(USE_EXPORT_MACROS_FOR_TESTING) && (PLATFORM(GTK) || PLATFORM(WIN)) +#define USE_EXPORT_MACROS_FOR_TESTING 1 #endif -#if !defined(WTF_USE_IMLANG_FONT_LINK2) && !OS(WINCE) -#define WTF_USE_IMLANG_FONT_LINK2 1 +#if PLATFORM(GTK) || PLATFORM(EFL) || (PLATFORM(QT) && !OS(DARWIN) && !OS(WINDOWS)) +#define USE_UNIX_DOMAIN_SOCKETS 1 #endif -#if !defined(ENABLE_COMPARE_AND_SWAP) && (OS(WINDOWS) || (COMPILER(GCC) && (CPU(X86) || CPU(X86_64) || CPU(ARM_THUMB2)))) -#define ENABLE_COMPARE_AND_SWAP 1 -#endif - -#define ENABLE_OBJECT_MARK_LOGGING 0 - -#if !defined(ENABLE_PARALLEL_GC) && !ENABLE(OBJECT_MARK_LOGGING) && (PLATFORM(MAC) || PLATFORM(IOS) || PLATFORM(QT) || PLATFORM(BLACKBERRY) || PLATFORM(GTK)) && ENABLE(COMPARE_AND_SWAP) -#define ENABLE_PARALLEL_GC 1 +#if !defined(USE_IMLANG_FONT_LINK2) +#define USE_IMLANG_FONT_LINK2 1 #endif #if !defined(ENABLE_GC_VALIDATION) && !defined(NDEBUG) @@ -1043,81 +994,161 @@ #define ENABLE_BINDING_INTEGRITY 1 #endif -#if PLATFORM(MAC) && !PLATFORM(IOS) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070 -#define WTF_USE_AVFOUNDATION 1 +#if PLATFORM(COCOA) +#define USE_AVFOUNDATION 1 #endif -#if (PLATFORM(IOS) && __IPHONE_OS_VERSION_MIN_REQUIRED >= 60000) || (PLATFORM(MAC) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1080) -#define WTF_USE_COREMEDIA 1 +#if !defined(ENABLE_TREE_DEBUGGING) +#if !defined(NDEBUG) +#define ENABLE_TREE_DEBUGGING 1 +#else +#define ENABLE_TREE_DEBUGGING 0 +#endif #endif -#if (PLATFORM(MAC) || (OS(WINDOWS) && USE(CG))) && !PLATFORM(IOS) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1080 -#define HAVE_AVFOUNDATION_MEDIA_SELECTION_GROUP 1 +#if PLATFORM(IOS) || PLATFORM(MAC) +#define USE_COREMEDIA 1 +#define HAVE_AVFOUNDATION_VIDEO_OUTPUT 1 #endif -#if (PLATFORM(MAC) || (OS(WINDOWS) && USE(CG))) && !PLATFORM(IOS) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090 -#define HAVE_AVFOUNDATION_LEGIBLE_OUTPUT_SUPPORT 1 +#if PLATFORM(IOS) || PLATFORM(MAC) || (OS(WINDOWS) && USE(CG)) +#define HAVE_AVFOUNDATION_MEDIA_SELECTION_GROUP 1 #endif -#if (PLATFORM(MAC) || (OS(WINDOWS) && USE(CG))) && !PLATFORM(IOS) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090 +#if PLATFORM(IOS) || PLATFORM(MAC) || (OS(WINDOWS) && USE(CG)) +#define HAVE_AVFOUNDATION_LEGIBLE_OUTPUT_SUPPORT 1 #define HAVE_MEDIA_ACCESSIBILITY_FRAMEWORK 1 #endif -#if PLATFORM(MAC) || PLATFORM(GTK) || (PLATFORM(WIN) && !USE(WINGDI) && !PLATFORM(WIN_CAIRO)) -#define WTF_USE_REQUEST_ANIMATION_FRAME_TIMER 1 +#if PLATFORM(IOS) || PLATFORM(MAC) +#define HAVE_AVFOUNDATION_LOADER_DELEGATE 1 #endif #if PLATFORM(MAC) -#define WTF_USE_REQUEST_ANIMATION_FRAME_DISPLAY_MONITOR 1 +#define USE_VIDEOTOOLBOX 1 #endif -#if PLATFORM(MAC) && (PLATFORM(IOS) || __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070) -#define HAVE_INVERTED_WHEEL_EVENTS 1 +#if PLATFORM(COCOA) || PLATFORM(GTK) || (PLATFORM(WIN) && !USE(WINGDI)) +#define USE_REQUEST_ANIMATION_FRAME_TIMER 1 +#endif + +#if PLATFORM(COCOA) +#define USE_REQUEST_ANIMATION_FRAME_DISPLAY_MONITOR 1 #endif #if PLATFORM(MAC) -#define WTF_USE_COREAUDIO 1 +#define USE_COREAUDIO 1 #endif -#if !defined(WTF_USE_ZLIB) && !PLATFORM(QT) -#define WTF_USE_ZLIB 1 +#if !defined(USE_ZLIB) +#define USE_ZLIB 1 +#endif + +#ifndef HAVE_QOS_CLASSES +#if PLATFORM(COCOA) +#define HAVE_QOS_CLASSES 1 +#endif #endif #if PLATFORM(QT) +#ifdef __cplusplus #include <qglobal.h> -#if defined(QT_OPENGL_ES_2) && !defined(WTF_USE_OPENGL_ES_2) -#define WTF_USE_OPENGL_ES_2 1 #endif +#if defined(QT_OPENGL_ES_2) && !defined(USE_OPENGL_ES_2) +#define USE_OPENGL_ES_2 1 #endif - -#if !PLATFORM(IOS) && PLATFORM(MAC) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 1080 -#define WTF_USE_CONTENT_FILTERING 1 #endif -#if COMPILER(GCC) && defined(__GCC_HAVE_SYNC_COMPARE_AND_SWAP_8) -#define HAVE_ATOMICS_64BIT 1 -#elif OS(WINDOWS) && (_WIN32_WINNT >= 0x0502) -#define HAVE_ATOMICS_64BIT 1 +#ifndef HAVE_VOUCHERS +#if PLATFORM(COCOA) +#define HAVE_VOUCHERS 1 +#endif #endif -#define WTF_USE_GRAMMAR_CHECKING 1 +#define USE_GRAMMAR_CHECKING 1 -#if PLATFORM(MAC) || PLATFORM(BLACKBERRY) || PLATFORM(EFL) -#define WTF_USE_UNIFIED_TEXT_CHECKING 1 +#if PLATFORM(COCOA) || PLATFORM(EFL) || PLATFORM(GTK) +#define USE_UNIFIED_TEXT_CHECKING 1 #endif #if PLATFORM(MAC) -#define WTF_USE_AUTOMATIC_TEXT_REPLACEMENT 1 +#define USE_AUTOMATIC_TEXT_REPLACEMENT 1 #endif -#if PLATFORM(MAC) && (PLATFORM(IOS) || __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070) +#if PLATFORM(MAC) /* Some platforms provide UI for suggesting autocorrection. */ -#define WTF_USE_AUTOCORRECTION_PANEL 1 +#define USE_AUTOCORRECTION_PANEL 1 +#endif + +#if PLATFORM(COCOA) /* Some platforms use spelling and autocorrection markers to provide visual cue. On such platform, if word with marker is edited, we need to remove the marker. */ -#define WTF_USE_MARKER_REMOVAL_UPON_EDITING 1 -#endif /* #if PLATFORM(MAC) && (PLATFORM(IOS) || __MAC_OS_X_VERSION_MIN_REQUIRED >= 1070) */ +#define USE_MARKER_REMOVAL_UPON_EDITING 1 +#endif -#if PLATFORM(MAC) || PLATFORM(IOS) -#define WTF_USE_AUDIO_SESSION 1 +#if PLATFORM(MAC) +#define USE_INSERTION_UNDO_GROUPING 1 +#endif + +#if (PLATFORM(MAC) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 101100) || PLATFORM(IOS) +#define HAVE_TIMINGDATAOPTIONS 1 +#endif + +#if PLATFORM(COCOA) +#define USE_AUDIO_SESSION 1 +#endif + +#if PLATFORM(COCOA) && !PLATFORM(IOS_SIMULATOR) +#define USE_IOSURFACE 1 +#endif + +#if PLATFORM(COCOA) +#define ENABLE_RESOURCE_USAGE 1 +#endif + +#if PLATFORM(GTK) || PLATFORM(EFL) +#undef ENABLE_OPENTYPE_VERTICAL +#define ENABLE_OPENTYPE_VERTICAL 1 +#define ENABLE_CSS3_TEXT_DECORATION_SKIP_INK 1 +#endif + +#if PLATFORM(COCOA) +#define ENABLE_CSS3_TEXT_DECORATION_SKIP_INK 1 +#endif + +#if PLATFORM(IOS) || (PLATFORM(MAC) && __MAC_OS_X_VERSION_MIN_REQUIRED > 101000) +#define ENABLE_PLATFORM_FONT_LOOKUP 1 +#endif + +#if COMPILER(MSVC) +#undef __STDC_LIMIT_MACROS +#define __STDC_LIMIT_MACROS +#if _MSC_VER < 1900 +#undef _HAS_EXCEPTIONS +#define _HAS_EXCEPTIONS 1 +#endif +#endif + +#if PLATFORM(MAC) +#define HAVE_NS_ACTIVITY 1 +#endif + +#if (OS(DARWIN) && USE(CG)) || USE(FREETYPE) || (PLATFORM(WIN) && (USE(CG) || USE(CAIRO))) +#undef ENABLE_OPENTYPE_MATH +#define ENABLE_OPENTYPE_MATH 1 +#endif + +/* Set TARGET_OS_IPHONE to 0 by default to allow using it as a guard + * in cross-platform the same way as it is used in OS(DARWIN) code. */ +#if !defined(TARGET_OS_IPHONE) && !OS(DARWIN) +#define TARGET_OS_IPHONE 0 +#endif + +#if PLATFORM(COCOA) +#define USE_MEDIATOOLBOX 1 +#endif + +/* While 10.10 has support for fences, it is missing some API important for our integration of them. */ +#if PLATFORM(IOS) || (PLATFORM(MAC) && __MAC_OS_X_VERSION_MIN_REQUIRED >= 101100) +#define HAVE_COREANIMATION_FENCES 1 #endif #endif /* WTF_Platform_h */ |