# 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. # IMPORTANT: # Please don't directly include this file if you are building via gyp_chromium, # since gyp_chromium is automatically forcing its inclusion. { # Variables expected to be overriden on the GYP command line (-D) or by # ~/.gyp/include.gypi. 'variables': { # Putting a variables dict inside another variables dict looks kind of # weird. This is done so that 'host_arch', 'chromeos', etc are defined as # variables within the outer variables dict here. This is necessary # to get these variables defined for the conditions within this variables # dict that operate on these variables. 'variables': { 'variables': { 'variables': { 'variables': { # Whether we're building a ChromeOS build. 'chromeos%': 0, # Whether we're building the cast (chromecast) shell 'chromecast%': 0, # Whether or not we are using the Aura windowing framework. 'use_aura%': 0, # Whether or not we are building the Ash shell. 'use_ash%': 0, # Whether or not we are using CRAS, the ChromeOS Audio Server. 'use_cras%': 0, # Use a raw surface abstraction. 'use_ozone%': 0, # Configure the build for small devices. See crbug.com/318413 'embedded%': 0, 'conditions': [ # Compute the architecture that we're building on. ['OS=="win" or OS=="ios"', { 'host_arch%': 'ia32', }, { 'host_arch%': '= 4.8 or clang. # http://gcc.gnu.org/wiki/DebugFission ['OS=="linux" and target_arch=="x64"', { 'linux_use_debug_fission%': 1, }, { 'linux_use_debug_fission%': 0, }], ['OS=="android" or OS=="ios"', { 'enable_captive_portal_detection%': 0, }, { 'enable_captive_portal_detection%': 1, }], # Enable Skia UI text drawing incrementally on different platforms. # http://crbug.com/105550 # # On Aura, this allows per-tile painting to be used in the browser # compositor. ['OS!="android"', { 'use_canvas_skia%': 1, }], ['chromeos==1', { 'enable_basic_printing%': 0, 'enable_print_preview%': 1, # When building for ChromeOS we dont want Chromium to use libjpeg_turbo. 'use_libjpeg_turbo%': 0, }], # Do not enable the Settings App on ChromeOS. ['enable_app_list==1 and chromeos==0', { 'enable_settings_app%': 1, }, { 'enable_settings_app%': 0, }], ['OS=="linux" and target_arch=="arm" and chromeos==0', { # Set some defaults for arm/linux chrome builds 'use_allocator%': 'none', # sysroot needs to be an absolute path otherwise it generates # incorrect results when passed to pkg-config 'sysroot%': '= 7) or target_arch=="ia32" or target_arch=="x64" or target_arch=="arm64" or target_arch=="mipsel")', { # Currently only supported on Android ARMv7+, ARM64, ia32, x64 and mipsel. # When enabled, this will also enable WebAudio support on # Android for these architectures. Default is enabled. Whether # WebAudio is actually available depends on runtime settings # and flags. 'use_openmax_dl_fft%': 1, }, { 'use_openmax_dl_fft%': 0, }], ['OS=="win" or OS=="linux"', { 'enable_mdns%' : 1, }], # Turns on compiler optimizations in V8 in Debug build, except # on android_clang, where we're hitting a weird linker error. # TODO(dpranke): http://crbug.com/266155 . ['OS=="android"', { 'v8_optimized_debug%': 1, }, { 'v8_optimized_debug%': 2, }], # Disable various features by default on embedded. ['embedded==1', { 'remoting%': 0, 'enable_basic_printing%': 0, 'enable_print_preview%': 0, }], # By default, use ICU data file (icudtl.dat) on all platforms # except when building Android WebView. # TODO(jshin): Handle 'use_system_icu' on Linux (Chromium). # Set the data reduction proxy origin for Android Webview. ['android_webview_build==0', { 'icu_use_data_file_flag%' : 1, }, { 'icu_use_data_file_flag%' : 0, }], ['OS=="win" or OS=="mac"', { 'enable_wifi_bootstrapping%' : 1, }], # Path to sas.dll, which provides the SendSAS function. # http://msdn.microsoft.com/en-us/library/windows/desktop/dd979761(v=vs.85).aspx ['target_arch=="x64"', { 'sas_dll_path%': '<(DEPTH)/third_party/platformsdk_win7/files/redist/amd64', }, { 'sas_dll_path%': '<(DEPTH)/third_party/platformsdk_win7/files/redist/x86', }], # Turn on JNI generation optimizations on non-WebView builds. ['OS=="android" and android_webview_build==0', { 'optimize_jni_generation%': 1, }, { 'optimize_jni_generation%': 0, }], # TODO(rmcilroy): Enable v8_use_external_startup_data on ChromeOS # http://crbug.com/421063 ['android_webview_build==0 and chromecast==0 and chromeos==0 and OS!="ios"', { 'v8_use_external_startup_data%': 1, }, { 'v8_use_external_startup_data%': 0, }], ], # Set this to 1 to enable use of concatenated impulse responses # for the HRTF panner in WebAudio. 'use_concatenated_impulse_responses': 1, # You can set the variable 'use_official_google_api_keys' to 1 # to use the Google-internal file containing official API keys # for Google Chrome even in a developer build. Setting this # variable explicitly to 1 will cause your build to fail if the # internal file is missing. # # The variable is documented here, but not handled in this file; # see //google_apis/determine_use_official_keys.gypi for the # implementation. # # Set the variable to 0 to not use the internal file, even when # it exists in your checkout. # # Leave it unset in your include.gypi to have the variable # implicitly set to 1 if you have # src/google_apis/internal/google_chrome_api_keys.h in your # checkout, and implicitly set to 0 if not. # # Note that official builds always behave as if the variable # was explicitly set to 1, i.e. they always use official keys, # and will fail to build if the internal file is missing. # # NOTE: You MUST NOT explicitly set the variable to 2 in your # include.gypi or by other means. Due to subtleties of GYP, this # is not the same as leaving the variable unset, even though its # default value in # //google_apis/determine_use_official_keys.gypi is 2. # Set these to bake the specified API keys and OAuth client # IDs/secrets into your build. # # If you create a build without values baked in, you can instead # set environment variables to provide the keys at runtime (see # src/google_apis/google_api_keys.h for details). Features that # require server-side APIs may fail to work if no keys are # provided. # # Note that if you are building an official build or if # use_official_google_api_keys has been set to 1 (explicitly or # implicitly), these values will be ignored and the official # keys will be used instead. 'google_api_key%': '', 'google_default_client_id%': '', 'google_default_client_secret%': '', # Native Client is enabled by default. 'disable_nacl%': '0', # Set to 1 to support old history files 'support_pre_M6_history_database%': '1', }, # Copy conditionally-set variables out one scope. 'branding%': '<(branding)', 'buildtype%': '<(buildtype)', 'target_arch%': '<(target_arch)', 'target_subarch%': '<(target_subarch)', 'mips_arch_variant%': '<(mips_arch_variant)', 'host_arch%': '<(host_arch)', 'toolkit_views%': '<(toolkit_views)', 'ui_compositor_image_transport%': '<(ui_compositor_image_transport)', 'use_aura%': '<(use_aura)', 'use_ash%': '<(use_ash)', 'use_cras%': '<(use_cras)', 'use_libpci%': '<(use_libpci)', 'use_openssl%': '<(use_openssl)', 'use_openssl_certs%': '<(use_openssl_certs)', 'use_nss%': '<(use_nss)', 'use_udev%': '<(use_udev)', 'os_bsd%': '<(os_bsd)', 'os_posix%': '<(os_posix)', 'use_dbus%': '<(use_dbus)', 'use_glib%': '<(use_glib)', 'use_pango%': '<(use_pango)', 'use_cairo%': '<(use_cairo)', 'use_ozone%': '<(use_ozone)', 'use_ozone_evdev%': '<(use_ozone_evdev)', 'use_xkbcommon%': '<(use_xkbcommon)', 'use_clipboard_aurax11%': '<(use_clipboard_aurax11)', 'desktop_linux%': '<(desktop_linux)', 'use_x11%': '<(use_x11)', 'use_gnome_keyring%': '<(use_gnome_keyring)', 'linux_fpic%': '<(linux_fpic)', 'chromeos%': '<(chromeos)', 'chromecast%': '<(chromecast)', 'enable_viewport%': '<(enable_viewport)', 'enable_hidpi%': '<(enable_hidpi)', 'image_loader_extension%': '<(image_loader_extension)', 'fastbuild%': '<(fastbuild)', 'dont_embed_build_metadata%': '<(dont_embed_build_metadata)', 'win_z7%': '<(win_z7)', 'dcheck_always_on%': '<(dcheck_always_on)', 'tracing_like_official_build%': '<(tracing_like_official_build)', 'arm_version%': '<(arm_version)', 'arm_neon%': '<(arm_neon)', 'arm_neon_optional%': '<(arm_neon_optional)', 'sysroot%': '<(sysroot)', 'chroot_cmd%': '<(chroot_cmd)', 'system_libdir%': '<(system_libdir)', 'component%': '<(component)', 'win_analyze%': '<(win_analyze)', 'enable_resource_whitelist_generation%': '<(enable_resource_whitelist_generation)', 'use_titlecase_in_grd%': '<(use_titlecase_in_grd)', 'use_third_party_translations%': '<(use_third_party_translations)', 'remoting%': '<(remoting)', 'enable_one_click_signin%': '<(enable_one_click_signin)', 'enable_pre_sync_backup%': '<(enable_pre_sync_backup)', 'enable_webrtc%': '<(enable_webrtc)', 'chromium_win_pch%': '<(chromium_win_pch)', 'configuration_policy%': '<(configuration_policy)', 'safe_browsing%': '<(safe_browsing)', 'enable_web_speech%': '<(enable_web_speech)', 'notifications%': '<(notifications)', 'clang_use_chrome_plugins%': '<(clang_use_chrome_plugins)', 'mac_want_real_dsym%': '<(mac_want_real_dsym)', 'asan%': '<(asan)', 'asan_blacklist%': '<(asan_blacklist)', 'asan_coverage%': '<(asan_coverage)', 'sanitizer_coverage%': '<(sanitizer_coverage)', 'asan_field_padding%': '<(asan_field_padding)', 'use_sanitizer_options%': '<(use_sanitizer_options)', 'syzyasan%': '<(syzyasan)', 'syzygy_optimize%': '<(syzygy_optimize)', 'lsan%': '<(lsan)', 'msan%': '<(msan)', 'msan_blacklist%': '<(msan_blacklist)', 'msan_track_origins%': '<(msan_track_origins)', 'tsan%': '<(tsan)', 'tsan_blacklist%': '<(tsan_blacklist)', 'ubsan%': '<(ubsan)', 'ubsan_blacklist%': '<(ubsan_blacklist)', 'ubsan_vptr%': '<(ubsan_vptr)', 'use_instrumented_libraries%': '<(use_instrumented_libraries)', 'use_custom_libcxx%': '<(use_custom_libcxx)', 'use_system_libcxx%': '<(use_system_libcxx)', 'clang_type_profiler%': '<(clang_type_profiler)', 'order_profiling%': '<(order_profiling)', 'order_text_section%': '<(order_text_section)', 'enable_extensions%': '<(enable_extensions)', 'enable_plugin_installation%': '<(enable_plugin_installation)', 'enable_plugins%': '<(enable_plugins)', 'enable_session_service%': '<(enable_session_service)', 'enable_themes%': '<(enable_themes)', 'enable_autofill_dialog%': '<(enable_autofill_dialog)', 'enable_prod_wallet_service%': '<(enable_prod_wallet_service)', 'enable_background%': '<(enable_background)', 'linux_use_bundled_gold%': '<(linux_use_bundled_gold)', 'linux_use_bundled_binutils%': '<(linux_use_bundled_binutils)', 'linux_use_gold_flags%': '<(linux_use_gold_flags)', 'linux_use_debug_fission%': '<(linux_use_debug_fission)', 'use_canvas_skia%': '<(use_canvas_skia)', 'test_isolation_mode%': '<(test_isolation_mode)', 'test_isolation_outdir%': '<(test_isolation_outdir)', 'enable_basic_printing%': '<(enable_basic_printing)', 'enable_print_preview%': '<(enable_print_preview)', 'enable_spellcheck%': '<(enable_spellcheck)', 'enable_google_now%': '<(enable_google_now)', 'cld_version%': '<(cld_version)', 'cld2_table_size%': '<(cld2_table_size)', 'enable_captive_portal_detection%': '<(enable_captive_portal_detection)', 'disable_file_support%': '<(disable_file_support)', 'disable_ftp_support%': '<(disable_ftp_support)', 'use_icu_alternatives_on_android%': '<(use_icu_alternatives_on_android)', 'enable_task_manager%': '<(enable_task_manager)', 'sas_dll_path%': '<(sas_dll_path)', 'wix_path%': '<(wix_path)', 'use_libjpeg_turbo%': '<(use_libjpeg_turbo)', 'use_system_libjpeg%': '<(use_system_libjpeg)', 'android_channel%': '<(android_channel)', 'android_webview_build%': '<(android_webview_build)', 'icu_use_data_file_flag%': '<(icu_use_data_file_flag)', 'gyp_managed_install%': 0, 'create_standalone_apk%': 1, 'enable_app_list%': '<(enable_app_list)', 'use_default_render_theme%': '<(use_default_render_theme)', 'enable_settings_app%': '<(enable_settings_app)', 'google_api_key%': '<(google_api_key)', 'google_default_client_id%': '<(google_default_client_id)', 'google_default_client_secret%': '<(google_default_client_secret)', 'enable_supervised_users%': '<(enable_supervised_users)', 'native_discardable_memory%': '<(native_discardable_memory)', 'native_memory_pressure_signals%': '<(native_memory_pressure_signals)', 'spdy_proxy_auth_property%': '<(spdy_proxy_auth_property)', 'spdy_proxy_auth_value%': '<(spdy_proxy_auth_value)', 'enable_mdns%' : '<(enable_mdns)', 'enable_service_discovery%' : '<(enable_service_discovery)', 'enable_wifi_bootstrapping%': '<(enable_wifi_bootstrapping)', 'enable_hangout_services_extension%' : '<(enable_hangout_services_extension)', 'v8_optimized_debug%': '<(v8_optimized_debug)', 'proprietary_codecs%': '<(proprietary_codecs)', 'use_goma%': '<(use_goma)', 'gomadir%': '<(gomadir)', 'use_lto%': '<(use_lto)', 'use_lto_o2%': '<(use_lto_o2)', 'gold_icf_level%': '<(gold_icf_level)', 'video_hole%': '<(video_hole)', 'support_pre_M6_history_database%': '<(support_pre_M6_history_database)', 'v8_use_external_startup_data%': '<(v8_use_external_startup_data)', # Use system protobuf instead of bundled one. 'use_system_protobuf%': 0, # Use system yasm instead of bundled one. 'use_system_yasm%': 0, # Use system ICU instead of bundled one. 'use_system_icu%' : 0, # Default to enabled PIE; this is important for ASLR but we may need to be # able to turn it off for various reasons. 'linux_disable_pie%': 0, # The release channel that this build targets. This is used to restrict # channel-specific build options, like which installer packages to create. # The default is 'all', which does no channel-specific filtering. 'channel%': 'all', # Override chromium_mac_pch and set it to 0 to suppress the use of # precompiled headers on the Mac. Prefix header injection may still be # used, but prefix headers will not be precompiled. This is useful when # using distcc to distribute a build to compile slaves that don't # share the same compiler executable as the system driving the compilation, # because precompiled headers rely on pointers into a specific compiler # executable's image. Setting this to 0 is needed to use an experimental # Linux-Mac cross compiler distcc farm. 'chromium_mac_pch%': 1, # The default value for mac_strip in target_defaults. This cannot be # set there, per the comment about variable% in a target_defaults. 'mac_strip_release%': 0, # Set to 1 to enable java code coverage. Instruments classes during build # to produce .ec files during runtime. 'emma_coverage%': 0, # EMMA filter string consisting of a list of inclusion/exclusion patterns # separated with whitespace and/or comma. Only has effect if # 'emma_coverage=1'. 'emma_filter%': '', # Set to 1 to enable running Android lint on java/class files. 'android_lint%': 1, # Although base/allocator lets you select a heap library via an # environment variable, the libcmt shim it uses sometimes gets in # the way. To disable it entirely, and switch to normal msvcrt, do e.g. # 'win_use_allocator_shim': 0, # 'win_release_RuntimeLibrary': 2 # to ~/.gyp/include.gypi, gclient runhooks --force, and do a release build. 'win_use_allocator_shim%': 1, # 1 = shim allocator via libcmt; 0 = msvcrt # TODO(bradnelson): eliminate this when possible. # To allow local gyp files to prevent release.vsprops from being included. # Yes(1) means include release.vsprops. # Once all vsprops settings are migrated into gyp, this can go away. 'msvs_use_common_release%': 1, # TODO(bradnelson): eliminate this when possible. # To allow local gyp files to override additional linker options for msvs. # Yes(1) means set use the common linker options. 'msvs_use_common_linker_extras%': 1, # TODO(sgk): eliminate this if possible. # It would be nicer to support this via a setting in 'target_defaults' # in chrome/app/locales/locales.gypi overriding the setting in the # 'Debug' configuration in the 'target_defaults' dict below, # but that doesn't work as we'd like. 'msvs_debug_link_incremental%': '2', # Needed for some of the largest modules. 'msvs_debug_link_nonincremental%': '1', # Turns on Use Library Dependency Inputs for linking chrome.dll on Windows # to get incremental linking to be faster in debug builds. 'incremental_chrome_dll%': '0', # Experimental setting to break chrome.dll into multiple pieces based on # process type. 'chrome_multiple_dll%': '0', # Experimental setting to optimize Chrome's DLLs with PGO. 'chrome_pgo_phase%': '0', # Whether the VS xtree header has been patched to disable warning 4702. If # it has, then we don't need to disable 4702 (unreachable code warning). # The patch is preapplied to the internal toolchain and hence all bots. 'msvs_xtree_patched%': '. Additional # documentation on these macros is available at # http://developer.apple.com/mac/library/technotes/tn2002/tn2064.html#SECTION3 # Chrome normally builds with the Mac OS X 10.6 SDK and sets the # deployment target to 10.6. Other projects, such as O3D, may # override these defaults. # Normally, mac_sdk_min is used to find an SDK that Xcode knows # about that is at least the specified version. In official builds, # the SDK must match mac_sdk_min exactly. If the SDK is installed # someplace that Xcode doesn't know about, set mac_sdk_path to the # path to the SDK; when set to a non-empty string, SDK detection # based on mac_sdk_min will be bypassed entirely. 'conditions': [ ['OS=="ios"', { 'mac_sdk_min%': '10.8', }, { # else OS!="ios" 'mac_sdk_min%': '10.6', }], ], 'mac_sdk_path%': '', 'mac_deployment_target%': '10.6', }, 'mac_sdk_min': '<(mac_sdk_min)', 'mac_sdk_path': '<(mac_sdk_path)', 'mac_deployment_target': '<(mac_deployment_target)', # Compile in Breakpad support by default so that it can be # tested, even if it is not enabled by default at runtime. 'mac_breakpad_compiled_in%': 1, 'conditions': [ # mac_product_name is set to the name of the .app bundle as it should # appear on disk. This duplicates data from # chrome/app/theme/chromium/BRANDING and # chrome/app/theme/google_chrome/BRANDING, but is necessary to get # these names into the build system. ['branding=="Chrome"', { 'mac_product_name%': 'Google Chrome', }, { # else: branding!="Chrome" 'mac_product_name%': 'Chromium', }], # Official mac builds require a specific OS X SDK, but iOS and # non-official mac builds do not. ['branding=="Chrome" and buildtype=="Official" and OS=="mac"', { 'mac_sdk%': '(nacl_untrusted_build)==1', { 'defines': [ 'USE_OPENSSL=1', 'USE_OPENSSL_CERTS=1', ], }], ['<(use_glib)==1 and >(nacl_untrusted_build)==0', { 'defines': ['USE_GLIB=1'], }], ['<(use_nss)==1 and >(nacl_untrusted_build)==0', { 'defines': ['USE_NSS=1'], }], ['<(chromeos)==1 and >(nacl_untrusted_build)==0', { 'defines': ['OS_CHROMEOS=1'], }], ['enable_wexit_time_destructors==1 and OS!="win"', { # TODO: Enable on Windows too, http://crbug.com/404525 'variables': { 'clang_warning_flags': ['-Wexit-time-destructors']}, }], ['chromium_code==0', { 'conditions': [ [ 'os_posix==1 and OS!="mac" and OS!="ios"', { # We don't want to get warnings from third-party code, # so remove any existing warning-enabling flags like -Wall. 'cflags!': [ '-Wall', '-Wextra', ], 'cflags_cc': [ # Don't warn about hash_map in third-party code. '-Wno-deprecated', ], 'cflags': [ # Don't warn about printf format problems. # This is off by default in gcc but on in Ubuntu's gcc(!). '-Wno-format', ], 'cflags_cc!': [ # Necessary because llvm.org/PR10448 is WONTFIX (crbug.com/90453). '-Wsign-compare', ] }], # TODO: Fix all warnings on chromeos too. [ 'os_posix==1 and OS!="mac" and OS!="ios" and (clang!=1 or chromeos==1)', { 'cflags!': [ '-Werror', ], }], [ 'os_posix==1 and os_bsd!=1 and OS!="mac" and OS!="android"', { 'cflags': [ # Don't warn about ignoring the return value from e.g. close(). # This is off by default in some gccs but on by default in others. # BSD systems do not support this option, since they are usually # using gcc 4.2.1, which does not have this flag yet. '-Wno-unused-result', ], }], [ 'OS=="win"', { 'defines': [ '_CRT_SECURE_NO_DEPRECATE', '_CRT_NONSTDC_NO_WARNINGS', '_CRT_NONSTDC_NO_DEPRECATE', '_SCL_SECURE_NO_DEPRECATE', ], 'msvs_disabled_warnings': [4800], 'msvs_settings': { 'VCCLCompilerTool': { 'WarningLevel': '3', 'WarnAsError': 'true', 'Detect64BitPortabilityProblems': 'false', }, }, 'conditions': [ ['buildtype=="Official"', { 'msvs_settings': { 'VCCLCompilerTool': { 'WarnAsError': 'false' }, } }], ['clang==1', { 'msvs_settings': { 'VCCLCompilerTool': { 'WarnAsError': 'false' }, } }], [ 'component=="shared_library"', { # TODO(darin): Unfortunately, some third_party code depends on base. 'msvs_disabled_warnings': [ 4251, # class 'std::xx' needs to have dll-interface. ], }], ], }], [ 'OS=="mac" or OS=="ios"', { 'xcode_settings': { 'WARNING_CFLAGS!': ['-Wall', '-Wextra'], }, 'conditions': [ ['buildtype=="Official"', { 'xcode_settings': { 'GCC_TREAT_WARNINGS_AS_ERRORS': 'NO', # -Werror }, }], ], }], [ 'OS=="ios"', { 'xcode_settings': { # TODO(ios): Fix remaining warnings in third-party code, then # remove this; the Mac cleanup didn't get everything that's # flagged in an iOS build. 'GCC_TREAT_WARNINGS_AS_ERRORS': 'NO', 'RUN_CLANG_STATIC_ANALYZER': 'NO', # Several internal ios directories generate numerous warnings for # -Wobjc-missing-property-synthesis. 'CLANG_WARN_OBJC_MISSING_PROPERTY_SYNTHESIS': 'NO', }, }], ], }, { 'includes': [ # Rules for excluding e.g. foo_win.cc from the build on non-Windows. 'filename_rules.gypi', ], # In Chromium code, we define __STDC_foo_MACROS in order to get the # C99 macros on Mac and Linux. 'defines': [ '__STDC_CONSTANT_MACROS', '__STDC_FORMAT_MACROS', ], 'conditions': [ ['OS=="win"', { # turn on warnings for signed/unsigned mismatch on chromium code. 'msvs_settings': { 'VCCLCompilerTool': { 'AdditionalOptions': ['/we4389'], }, }, }], ['OS=="win" and component=="shared_library"', { 'msvs_disabled_warnings': [ 4251, # class 'std::xx' needs to have dll-interface. ], }], ], }], ], # target_conditions for 'target_defaults' 'default_configuration': 'Debug', 'configurations': { # VCLinkerTool LinkIncremental values below: # 0 == default # 1 == /INCREMENTAL:NO # 2 == /INCREMENTAL # Debug links incremental, Release does not. # # Abstract base configurations to cover common attributes. # 'Common_Base': { 'abstract': 1, 'msvs_configuration_attributes': { 'OutputDirectory': '<(DEPTH)\\build\\<(build_dir_prefix)$(ConfigurationName)', 'IntermediateDirectory': '$(OutDir)\\obj\\$(ProjectName)', 'CharacterSet': '1', }, # Add the default import libs. 'msvs_settings':{ 'VCLinkerTool': { 'AdditionalDependencies': [ 'kernel32.lib', 'gdi32.lib', 'winspool.lib', 'comdlg32.lib', 'advapi32.lib', 'shell32.lib', 'ole32.lib', 'oleaut32.lib', 'user32.lib', 'uuid.lib', 'odbc32.lib', 'odbccp32.lib', 'delayimp.lib', 'credui.lib', 'netapi32.lib', ], 'AdditionalOptions': [ # Suggested by Microsoft Devrel to avoid # LINK : fatal error LNK1248: image size (80000000) exceeds maximum allowable size (80000000) # which started happening more regularly after VS2013 Update 4. '/maxilksize:2147483647', ], }, }, }, 'x86_Base': { 'abstract': 1, 'msvs_settings': { 'VCLinkerTool': { 'MinimumRequiredVersion': '5.01', # XP. 'TargetMachine': '1', }, 'VCLibrarianTool': { 'TargetMachine': '1', }, }, 'msvs_configuration_platform': 'Win32', }, 'x64_Base': { 'abstract': 1, 'msvs_configuration_platform': 'x64', 'msvs_settings': { 'VCLinkerTool': { # Make sure to understand http://crbug.com/361720 if you want to # increase this. 'MinimumRequiredVersion': '5.02', # Server 2003. 'TargetMachine': '17', # x86 - 64 'AdditionalLibraryDirectories!': ['<(windows_sdk_path)/Lib/win8/um/x86'], 'AdditionalLibraryDirectories': ['<(windows_sdk_path)/Lib/win8/um/x64'], # Doesn't exist x64 SDK. Should use oleaut32 in any case. 'IgnoreDefaultLibraryNames': [ 'olepro32.lib' ], }, 'VCLibrarianTool': { 'AdditionalLibraryDirectories!': ['<(windows_sdk_path)/Lib/win8/um/x86'], 'AdditionalLibraryDirectories': ['<(windows_sdk_path)/Lib/win8/um/x64'], 'TargetMachine': '17', # x64 }, }, }, 'Debug_Base': { 'abstract': 1, 'defines': [ 'DYNAMIC_ANNOTATIONS_ENABLED=1', 'WTF_USE_DYNAMIC_ANNOTATIONS=1', ], 'xcode_settings': { 'GCC_OPTIMIZATION_LEVEL': '<(mac_debug_optimization)', 'OTHER_CFLAGS': [ '<@(debug_extra_cflags)', ], }, 'msvs_settings': { 'VCCLCompilerTool': { 'Optimization': '<(win_debug_Optimization)', 'PreprocessorDefinitions': ['_DEBUG'], 'BasicRuntimeChecks': '<(win_debug_RuntimeChecks)', 'RuntimeLibrary': '<(win_debug_RuntimeLibrary)', 'conditions': [ # According to MSVS, InlineFunctionExpansion=0 means # "default inlining", not "/Ob0". # Thus, we have to handle InlineFunctionExpansion==0 separately. ['win_debug_InlineFunctionExpansion==0', { 'AdditionalOptions': ['/Ob0'], }], ['win_debug_InlineFunctionExpansion!=""', { 'InlineFunctionExpansion': '<(win_debug_InlineFunctionExpansion)', }], ['win_debug_disable_iterator_debugging==1', { 'PreprocessorDefinitions': ['_HAS_ITERATOR_DEBUGGING=0'], }], # if win_debug_OmitFramePointers is blank, leave as default ['win_debug_OmitFramePointers==1', { 'OmitFramePointers': 'true', }], ['win_debug_OmitFramePointers==0', { 'OmitFramePointers': 'false', # The above is not sufficient (http://crbug.com/106711): it # simply eliminates an explicit "/Oy", but both /O2 and /Ox # perform FPO regardless, so we must explicitly disable. # We still want the false setting above to avoid having # "/Oy /Oy-" and warnings about overriding. 'AdditionalOptions': ['/Oy-'], }], ], 'AdditionalOptions': [ '<@(win_debug_extra_cflags)', ], }, 'VCLinkerTool': { 'LinkIncremental': '<(msvs_debug_link_incremental)', # ASLR makes debugging with windbg difficult because Chrome.exe and # Chrome.dll share the same base name. As result, windbg will # name the Chrome.dll module like chrome_, where # typically changes with each launch. This in turn # means that breakpoints in Chrome.dll don't stick from one launch # to the next. For this reason, we turn ASLR off in debug builds. # Note that this is a three-way bool, where 0 means to pick up # the default setting, 1 is off and 2 is on. 'RandomizedBaseAddress': 1, }, 'VCResourceCompilerTool': { 'PreprocessorDefinitions': ['_DEBUG'], }, }, 'conditions': [ ['OS=="linux" or OS=="android"', { 'target_conditions': [ ['_toolset=="target"', { 'cflags': [ '<@(debug_extra_cflags)', ], }], ], }], ['OS=="linux" and target_arch!="ia32" and disable_glibcxx_debug==0', { # Enable libstdc++ debugging facilities to help catch problems # early, see http://crbug.com/65151 . # TODO(phajdan.jr): Should we enable this for all of POSIX? 'defines': ['_GLIBCXX_DEBUG=1',], }], ['release_valgrind_build==0', { 'xcode_settings': { 'OTHER_CFLAGS': [ '-fstack-protector-all', # Implies -fstack-protector ], }, }], ['clang==1', { 'cflags': [ # Allow comparing the address of references and 'this' against 0 # in debug builds. Technically, these can never be null in # well-defined C/C++ and Clang can optimize such checks away in # release builds, but they may be used in asserts in debug builds. '-Wno-undefined-bool-conversion', '-Wno-tautological-undefined-compare', ], 'xcode_settings': { 'OTHER_CFLAGS': [ '-Wno-undefined-bool-conversion', '-Wno-tautological-undefined-compare', ], }, 'msvs_settings': { 'VCCLCompilerTool': { 'AdditionalOptions': [ '-Wno-undefined-bool-conversion', '-Wno-tautological-undefined-compare', ], }, }, }], ], }, 'Release_Base': { 'abstract': 1, 'defines': [ 'NDEBUG', ], 'xcode_settings': { 'DEAD_CODE_STRIPPING': 'YES', # -Wl,-dead_strip 'GCC_OPTIMIZATION_LEVEL': '<(mac_release_optimization)', 'OTHER_CFLAGS': [ '<@(release_extra_cflags)', ], }, 'msvs_settings': { 'VCCLCompilerTool': { 'RuntimeLibrary': '<(win_release_RuntimeLibrary)', 'conditions': [ # In official builds, each target will self-select # an optimization level. ['buildtype!="Official"', { 'Optimization': '<(win_release_Optimization)', }, ], # According to MSVS, InlineFunctionExpansion=0 means # "default inlining", not "/Ob0". # Thus, we have to handle InlineFunctionExpansion==0 separately. ['win_release_InlineFunctionExpansion==0', { 'AdditionalOptions': ['/Ob0'], }], ['win_release_InlineFunctionExpansion!=""', { 'InlineFunctionExpansion': '<(win_release_InlineFunctionExpansion)', }], # if win_release_OmitFramePointers is blank, leave as default ['win_release_OmitFramePointers==1', { 'OmitFramePointers': 'true', }], ['win_release_OmitFramePointers==0', { 'OmitFramePointers': 'false', # The above is not sufficient (http://crbug.com/106711): it # simply eliminates an explicit "/Oy", but both /O2 and /Ox # perform FPO regardless, so we must explicitly disable. # We still want the false setting above to avoid having # "/Oy /Oy-" and warnings about overriding. 'AdditionalOptions': ['/Oy-'], }], ['asan==0', { # Put data in separate COMDATs. This allows the linker # to put bit-identical constants at the same address even if # they're unrelated constants, which saves binary size. # This optimization can't be used when ASan is enabled because # it is not compatible with the ASan ODR checker. 'AdditionalOptions': ['/Gw'], }], ], 'AdditionalOptions': [ '/d2Zi+', # Improve debugging of Release builds. '/Zc:inline', # Remove unreferenced COMDAT (faster links). '<@(win_release_extra_cflags)', ], }, 'VCLinkerTool': { # LinkIncremental is a tri-state boolean, where 0 means default # (i.e., inherit from parent solution), 1 means false, and # 2 means true. 'LinkIncremental': '1', # This corresponds to the /PROFILE flag which ensures the PDB # file contains FIXUP information (growing the PDB file by about # 5%) but does not otherwise alter the output binary. This # information is used by the Syzygy optimization tool when # decomposing the release image. 'Profile': 'true', }, }, 'conditions': [ ['msvs_use_common_release', { 'includes': ['release.gypi'], }], ['release_valgrind_build==0 and tsan==0', { 'defines': [ 'NVALGRIND', 'DYNAMIC_ANNOTATIONS_ENABLED=0', ], }, { 'defines': [ 'MEMORY_TOOL_REPLACES_ALLOCATOR', 'MEMORY_SANITIZER_INITIAL_SIZE', 'DYNAMIC_ANNOTATIONS_ENABLED=1', 'WTF_USE_DYNAMIC_ANNOTATIONS=1', ], }], ['OS=="win"', { 'defines': ['NO_TCMALLOC'], }], # _FORTIFY_SOURCE isn't really supported by Clang now, see # http://llvm.org/bugs/show_bug.cgi?id=16821. # It seems to work fine with Ubuntu 12 headers though, so use it # in official builds. ['os_posix==1 and (asan!=1 and msan!=1 and tsan!=1 and lsan!=1 and ubsan!=1) and (OS!="linux" or clang!=1 or buildtype=="Official")', { 'target_conditions': [ ['chromium_code==1', { # Non-chromium code is not guaranteed to compile cleanly # with _FORTIFY_SOURCE. Also, fortified build may fail # when optimizations are disabled, so only do that for Release # build. 'defines': [ '_FORTIFY_SOURCE=2', ], }], ], }], ['OS=="linux" or OS=="android"', { 'target_conditions': [ ['_toolset=="target"', { 'cflags': [ '<@(release_extra_cflags)', ], 'conditions': [ ['enable_resource_whitelist_generation==1', { 'cflags': [ '-Wunknown-pragmas -Wno-error=unknown-pragmas', ], }], ], }], ], }], ['OS=="ios"', { 'defines': [ 'NS_BLOCK_ASSERTIONS=1', ], }], ], }, # # Concrete configurations # 'Debug': { 'inherit_from': ['Common_Base', 'x86_Base', 'Debug_Base'], }, 'Release': { 'inherit_from': ['Common_Base', 'x86_Base', 'Release_Base'], }, 'conditions': [ [ 'OS=="ios"', { 'Profile': { 'inherit_from': ['Common_Base', 'x86_Base', 'Release_Base'], 'target_conditions': [ [ '_type=="executable"', { # To get a real .dSYM bundle produced by dsymutil, set the # debug information format to dwarf-with-dsym. Since # strip_from_xcode will not be used, set Xcode to do the # stripping as well. 'xcode_settings': { 'DEBUG_INFORMATION_FORMAT': 'dwarf-with-dsym', 'DEPLOYMENT_POSTPROCESSING': 'YES', 'STRIP_INSTALLED_PRODUCT': 'YES', }, }], ], }, }], [ 'OS=="win"', { # TODO(bradnelson): add a gyp mechanism to make this more graceful. 'Debug_x64': { 'inherit_from': ['Common_Base', 'x64_Base', 'Debug_Base'], }, 'Release_x64': { 'inherit_from': ['Common_Base', 'x64_Base', 'Release_Base'], }, }], ], }, }, 'conditions': [ ['os_posix==1', { 'target_defaults': { 'ldflags': [ '-Wl,-z,now', '-Wl,-z,relro', ], # TODO(glider): enable the default options on other systems. 'conditions': [ ['use_sanitizer_options==1 and ((OS=="linux" and (chromeos==0 or target_arch!="ia32")) or OS=="mac")', { 'dependencies': [ '<(DEPTH)/build/sanitizers/sanitizers.gyp:sanitizer_options', ], }], ], }, }], # TODO(jochen): Enable this on chromeos on arm. http://crbug.com/356580 ['os_posix==1 and disable_fatal_linker_warnings==0 and use_evdev_gestures==0 and (chromeos==0 or target_arch!="arm")', { 'target_defaults': { 'ldflags': [ '-Wl,--fatal-warnings', ], }, }], # TODO(thakis): Enable this everywhere. http://crbug.com/371125 ['(OS=="linux" or OS=="android") and asan==0 and msan==0 and tsan==0 and ubsan==0 and ubsan_vptr==0', { 'target_defaults': { 'ldflags': [ '-Wl,-z,defs', ], }, }], ['os_posix==1 and chromeos==0', { # Chrome OS enables -fstack-protector-strong via its build wrapper, # and we want to avoid overriding this, so stack-protector is only # enabled when not building on Chrome OS. # TODO(phajdan.jr): Use -fstack-protector-strong when our gcc # supports it. 'target_defaults': { 'cflags': [ '-fstack-protector', '--param=ssp-buffer-size=4', ], }, }], ['os_posix==1 and OS!="mac" and OS!="ios"', { 'target_defaults': { # Enable -Werror by default, but put it in a variable so it can # be disabled in ~/.gyp/include.gypi on the valgrind builders. 'variables': { 'werror%': '-Werror', 'libraries_for_target%': '', }, 'defines': [ '_FILE_OFFSET_BITS=64', ], 'cflags': [ '<(werror)', # See note above about the werror variable. '-pthread', '-fno-strict-aliasing', # See http://crbug.com/32204 '-Wall', # TODO(evan): turn this back on once all the builds work. # '-Wextra', # Don't warn about unused function params. We use those everywhere. '-Wno-unused-parameter', # Don't warn about the "struct foo f = {0};" initialization pattern. '-Wno-missing-field-initializers', # Don't export any symbols (for example, to plugins we dlopen()). # Note: this is *required* to make some plugins work. '-fvisibility=hidden', '-pipe', ], 'cflags_cc': [ '-fno-exceptions', '-fno-rtti', '-fno-threadsafe-statics', # Make inline functions have hidden visiblity by default. # Surprisingly, not covered by -fvisibility=hidden. '-fvisibility-inlines-hidden', # GCC turns on -Wsign-compare for C++ under -Wall, but clang doesn't, # so we specify it explicitly. (llvm.org/PR10448, crbug.com/90453) '-Wsign-compare', ], 'ldflags': [ '-pthread', '-Wl,-z,noexecstack', ], 'libraries' : [ '<(libraries_for_target)', ], 'configurations': { 'Debug_Base': { 'variables': { 'debug_optimize%': '0', }, 'defines': [ '_DEBUG', ], 'cflags': [ '-O>(debug_optimize)', '-g', '-gdwarf-4', ], 'conditions' : [ ['OS=="android"', { 'ldflags': [ # Warn in case of text relocations. '-Wl,--warn-shared-textrel', ], }], ['OS=="android" and android_full_debug==0', { # Some configurations are copied from Release_Base to reduce # the binary size. 'variables': { 'debug_optimize%': 's', }, 'cflags': [ '-fdata-sections', '-ffunction-sections', ], 'ldflags': [ '-Wl,-O1', '-Wl,--as-needed', ], }], ['OS=="android" and android_full_debug==0 and target_arch!="arm64"', { # We don't omit frame pointers on arm64 since they are required # to correctly unwind stackframes which contain system library # function frames (crbug.com/391706). 'cflags': [ '-fomit-frame-pointer', ], }], ['OS=="linux" and target_arch=="ia32"', { 'ldflags': [ '-Wl,--no-as-needed', ], }], ['debug_unwind_tables==1', { 'cflags': ['-funwind-tables'], }, { 'cflags': ['-fno-unwind-tables', '-fno-asynchronous-unwind-tables'], 'defines': ['NO_UNWIND_TABLES'], }], # TODO(mostynb): shuffle clang/gcc_version/binutils_version # definitions in to the right scope to use them when setting # linux_use_debug_fission, so it can be used here alone. ['linux_use_debug_fission==1 and linux_use_gold_flags==1 and (clang==1 or gcc_version>=48) and binutils_version>=223', { 'cflags': ['-gsplit-dwarf'], }], ], }, 'Release_Base': { 'variables': { 'release_optimize%': '2', # Binaries become big and gold is unable to perform GC # and remove unused sections for some of test targets # on 32 bit platform. # (This is currently observed only in chromeos valgrind bots) # The following flag is to disable --gc-sections linker # option for these bots. 'no_gc_sections%': 0, # TODO(bradnelson): reexamine how this is done if we change the # expansion of configurations 'release_valgrind_build%': 0, }, 'cflags': [ '-O<(release_optimize)', # Don't emit the GCC version ident directives, they just end up # in the .comment section taking up binary size. '-fno-ident', # Put data and code in their own sections, so that unused symbols # can be removed at link time with --gc-sections. '-fdata-sections', '-ffunction-sections', ], 'ldflags': [ # Specifically tell the linker to perform optimizations. # See http://lwn.net/Articles/192624/ . '-Wl,-O1', '-Wl,--as-needed', ], 'conditions' : [ ['no_gc_sections==0', { 'ldflags': [ '-Wl,--gc-sections', ], }], ['OS=="android" and target_arch!="arm64"', { # We don't omit frame pointers on arm64 since they are required # to correctly unwind stackframes which contain system library # function frames (crbug.com/391706). 'cflags': [ '-fomit-frame-pointer', ] }], ['OS=="android"', { 'variables': { 'release_optimize%': 's', }, 'ldflags': [ # Warn in case of text relocations. '-Wl,--warn-shared-textrel', ], }], ['profiling==1', { 'cflags': [ '-fno-omit-frame-pointer', '-g', ], 'conditions' : [ ['profiling_full_stack_frames==1', { 'cflags': [ '-fno-inline', '-fno-optimize-sibling-calls', ], }], ], }], ['release_unwind_tables==1', { 'cflags': ['-funwind-tables'], }, { 'cflags': ['-fno-unwind-tables', '-fno-asynchronous-unwind-tables'], 'defines': ['NO_UNWIND_TABLES'], }], ], }, }, 'conditions': [ ['target_arch=="ia32"', { 'target_conditions': [ ['_toolset=="target"', { 'asflags': [ # Needed so that libs with .s files (e.g. libicudata.a) # are compatible with the general 32-bit-ness. '-32', ], # All floating-point computations on x87 happens in 80-bit # precision. Because the C and C++ language standards allow # the compiler to keep the floating-point values in higher # precision than what's specified in the source and doing so # is more efficient than constantly rounding up to 64-bit or # 32-bit precision as specified in the source, the compiler, # especially in the optimized mode, tries very hard to keep # values in x87 floating-point stack (in 80-bit precision) # as long as possible. This has important side effects, that # the real value used in computation may change depending on # how the compiler did the optimization - that is, the value # kept in 80-bit is different than the value rounded down to # 64-bit or 32-bit. There are possible compiler options to # make this behavior consistent (e.g. -ffloat-store would keep # all floating-values in the memory, thus force them to be # rounded to its original precision) but they have significant # runtime performance penalty. # # -mfpmath=sse -msse2 makes the compiler use SSE instructions # which keep floating-point values in SSE registers in its # native precision (32-bit for single precision, and 64-bit # for double precision values). This means the floating-point # value used during computation does not change depending on # how the compiler optimized the code, since the value is # always kept in its specified precision. # # Refer to http://crbug.com/348761 for rationale behind SSE2 # being a minimum requirement for 32-bit Linux builds and # http://crbug.com/313032 for an example where this has "bit" # us in the past. 'cflags': [ '-msse2', '-mfpmath=sse', '-mmmx', # Allows mmintrin.h for MMX intrinsics. '-m32', ], 'ldflags': [ '-m32', ], 'conditions': [ # Use gold linker for Android ia32 target. ['OS=="android"', { 'ldflags': [ '-fuse-ld=gold', ], }], # Install packages have started cropping up with # different headers between the 32-bit and 64-bit # versions, so we have to shadow those differences off # and make sure a 32-bit-on-64-bit build picks up the # right files. # For android build, use NDK headers instead of host headers ['host_arch!="ia32" and OS!="android"', { 'include_dirs+': [ '/usr/include32', ], }], ], }], ], }], ['target_arch=="x64"', { 'target_conditions': [ ['_toolset=="target"', { 'conditions': [ # Use gold linker for Android x64 target. ['OS=="android"', { 'ldflags': [ '-fuse-ld=gold', ], }], ], 'cflags': [ '-m64', '-march=x86-64', ], 'ldflags': [ '-m64', ], }], ], }], ['target_arch=="arm"', { 'target_conditions': [ ['_toolset=="target"', { 'conditions': [ ['clang==0', { 'cflags_cc': [ # The codesourcery arm-2009q3 toolchain warns at that the ABI # has changed whenever it encounters a varargs function. This # silences those warnings, as they are not helpful and # clutter legitimate warnings. '-Wno-abi', ], }], ['clang==1 and arm_arch!="" and OS!="android"', { 'cflags': [ '-target arm-linux-gnueabihf', ], 'ldflags': [ '-target arm-linux-gnueabihf', ], }], ['arm_arch!=""', { 'cflags': [ '-march=<(arm_arch)', ], 'conditions': [ ['use_lto==1 or use_lto_o2==1', { 'ldflags': [ '-march=<(arm_arch)', ], }], ], }], ['clang==1 and OS!="android"', { 'cflags': [ # We need to disable clang's builtin assembler as it can't # handle several asm files, crbug.com/124610 '-no-integrated-as', ], }], ['arm_tune!=""', { 'cflags': [ '-mtune=<(arm_tune)', ], 'conditions': [ ['use_lto==1 or use_lto_o2==1', { 'ldflags': [ '-mtune=<(arm_tune)', ], }], ], }], ['arm_fpu!=""', { 'cflags': [ '-mfpu=<(arm_fpu)', ], 'conditions': [ ['use_lto==1 or use_lto_o2==1', { 'ldflags': [ '-mfpu=<(arm_fpu)', ], }], ], }], ['arm_float_abi!=""', { 'cflags': [ '-mfloat-abi=<(arm_float_abi)', ], 'conditions': [ ['use_lto==1 or use_lto_o2==1', { 'ldflags': [ '-mfloat-abi=<(arm_float_abi)', ], }], ], }], ['arm_thumb==1', { 'cflags': [ '-mthumb', ], 'conditions': [ ['use_lto==1 or use_lto_o2==1', { 'ldflags': [ '-mthumb', ], }], ], }], ['OS=="android"', { # Most of the following flags are derived from what Android # uses by default when building for arm, reference for which # can be found in the following file in the Android NDK: # toolchains/arm-linux-androideabi-4.9/setup.mk 'cflags': [ # The tree-sra optimization (scalar replacement for # aggregates enabling subsequent optimizations) leads to # invalid code generation when using the Android NDK's # compiler (r5-r7). This can be verified using # webkit_unit_tests' WTF.Checked_int8_t test. '-fno-tree-sra', # The following option is disabled to improve binary # size and performance in gcc 4.9. '-fno-caller-saves', '-Wno-psabi', ], # Android now supports .relro sections properly. # NOTE: While these flags enable the generation of .relro # sections, the generated libraries can still be loaded on # older Android platform versions. 'ldflags': [ '-Wl,-z,relro', '-Wl,-z,now', '-fuse-ld=gold', ], 'conditions': [ ['gcc_version==48 and clang==0', { 'cflags': [ # The following 5 options are disabled to save on # binary size in GCC 4.8. '-fno-partial-inlining', '-fno-early-inlining', '-fno-tree-copy-prop', '-fno-tree-loop-optimize', '-fno-move-loop-invariants', ], }], ['arm_thumb==1', { 'cflags': [ '-mthumb-interwork' ], }], ['profiling==1', { 'cflags': [ # Thumb code with frame pointer makes chrome crash # early. '-marm', '-mapcs-frame', # Required by -fno-omit-frame-pointer. # The perf report sometimes incorrectly attributes # code from tail calls. '-fno-optimize-sibling-calls', ], 'cflags!': [ '-fomit-frame-pointer', ], }], ['clang==1', { 'cflags!': [ # Clang does not support the following options. '-mthumb-interwork', '-finline-limit=64', '-fno-tree-sra', '-fno-caller-saves', '-Wno-psabi', ], 'cflags': [ # TODO(hans) Enable integrated-as (crbug.com/124610). '-no-integrated-as', '-B<(android_toolchain)', # Else /usr/bin/as gets picked up. ], 'ldflags': [ # Let clang find the ld.gold in the NDK. '--gcc-toolchain=<(android_toolchain)/..', ], }], ['asan==1', { 'cflags': [ '-marm', # Required for frame pointer based stack traces. ], }], ], }], ['chromecast==1', { 'cflags': [ # We set arm_arch to "" so that -march compiler option # is not set. Otherwise a gcc bug that would complain # about it conflicting with '-mcpu=cortex-a9'. The flag # '-march=armv7-a' is actually redundant anyway because # it is enabled by default when we built the toolchain. # And using '-mcpu=cortex-a9' should be sufficient. '-mcpu=cortex-a9', '-funwind-tables', # Breakpad requires symbols with debugging information '-g', ], 'ldflags': [ # We want to statically link libstdc++/libgcc_s. '-static-libstdc++', '-static-libgcc', ], 'cflags!': [ # Some components in Chromium (e.g. v8, skia, ffmpeg) # define their own cflags for arm builds that could # conflict with the flags we set here (e.g. # '-mcpu=cortex-a9'). Remove these flags explicitly. '-march=armv7-a', '-mtune=cortex-a8', ], }], ], }], ], }], ['target_arch=="arm64"', { 'target_conditions': [ ['_toolset=="target"', { 'conditions': [ ['OS=="android"', { 'cflags!': [ '-fstack-protector', # stack protector is always enabled on arm64. ], }], # TODO: Remove webview test once webview fully compiles from # Chromium. crbug.com/440793 ['OS=="android" and android_webview_build==0', { 'ldflags': [ '-fuse-ld=gold', ], }], ], }], ], }], ['target_arch=="mipsel"', { 'target_conditions': [ ['_toolset=="target"', { 'conditions': [ ['android_webview_build==0 and mips_arch_variant=="r6"', { 'cflags': ['-mips32r6', '-Wa,-mips32r6'], 'conditions': [ ['OS=="android"', { 'ldflags': ['-mips32r6', '-Wl,-melf32ltsmip',], }], ], }], ['android_webview_build==0 and mips_arch_variant=="r2"', { 'cflags': ['-mips32r2', '-Wa,-mips32r2'], }], ['android_webview_build==0 and mips_arch_variant=="r1"', { 'cflags': ['-mips32', '-Wa,-mips32'], }], ], 'ldflags': [ '-Wl,--no-keep-memory' ], 'cflags_cc': [ '-Wno-uninitialized', ], }], ], }], ['target_arch=="mips64el"', { 'target_conditions': [ ['_toolset=="target"', { 'conditions': [ ['android_webview_build==0 and mips_arch_variant=="r6"', { 'cflags': ['-mips64r6', '-Wa,-mips64r6'], 'ldflags': [ '-mips64r6' ], }], ['android_webview_build==0 and mips_arch_variant=="r2"', { 'cflags': ['-mips64r2', '-Wa,-mips64r2'], 'ldflags': [ '-mips64r2' ], }], ], 'cflags_cc': [ '-Wno-uninitialized', ], }], ], }], ['linux_fpic==1', { 'cflags': [ '-fPIC', ], 'ldflags': [ '-fPIC', ], }], ['sysroot!=""', { 'target_conditions': [ ['_toolset=="target"', { 'cflags': [ '--sysroot=<(sysroot)', ], 'ldflags': [ '--sysroot=<(sysroot)', '=223', { # Newer binutils don't set DT_RPATH unless you disable "new" dtags # and the new DT_RUNPATH doesn't work without --no-as-needed flag. # FIXME(mithro): Figure out the --as-needed/--no-as-needed flags # inside this file to allow usage of --no-as-needed and removal of # this flag. 'ldflags': [ '-Wl,--disable-new-dtags', ], }], ['gcc_version>=47 and clang==0', { 'target_conditions': [ ['_toolset=="target"', { 'cflags_cc': [ '-std=gnu++11', # See comment for -Wno-c++11-narrowing. '-Wno-narrowing', # TODO(thakis): Remove, http://crbug.com/263960 '-Wno-literal-suffix', ], }], ], }], ['host_gcc_version>=47 and clang==0 and host_clang==0', { 'target_conditions': [ ['_toolset=="host"', { 'cflags_cc': [ '-std=gnu++11', # See comment for -Wno-c++11-narrowing. '-Wno-narrowing', # TODO(thakis): Remove, http://crbug.com/263960 '-Wno-literal-suffix', ], }], ], }], ], }, }], # FreeBSD-specific options; note that most FreeBSD options are set above, # with Linux. ['OS=="freebsd"', { 'target_defaults': { 'ldflags': [ '-Wl,--no-keep-memory', ], }, }], # Android-specific options; note that most are set above with Linux. ['OS=="android"', { 'variables': { # This is a unique identifier for a given build. It's used for # identifying various build artifacts corresponding to a particular # build of chrome (e.g. where to find archived symbols). 'chrome_build_id%': '', 'conditions': [ # Figure this out early since it needs symbols from libgcc.a, so it # has to be before that in the set of libraries. ['component=="shared_library"', { 'android_stlport_library': 'stlport_shared', }, { 'android_stlport_library': 'stlport_static', }], ], # Placing this variable here prevents from forking libvpx, used # by remoting. Remoting is off, so it needn't built, # so forking it's deps seems like overkill. # But this variable need defined to properly run gyp. # A proper solution is to have an OS==android conditional # in third_party/libvpx/libvpx.gyp to define it. 'libvpx_path': 'lib/linux/arm', }, 'target_defaults': { 'variables': { 'release_extra_cflags%': '', 'conditions': [ # If we're using the components build, append "cr" to all shared # libraries to avoid naming collisions with android system library # versions with the same name (e.g. skia, icu). ['component=="shared_library"', { 'android_product_extension': 'cr.so', }, { 'android_product_extension': 'so', } ], ], }, 'target_conditions': [ ['_type=="shared_library"', { 'product_extension': '<(android_product_extension)', }], # Settings for building device targets using Android's toolchain. # These are based on the setup.mk file from the Android NDK. # # The NDK Android executable link step looks as follows: # $LDFLAGS # $(TARGET_CRTBEGIN_DYNAMIC_O) <-- crtbegin.o # $(PRIVATE_OBJECTS) <-- The .o that we built # $(PRIVATE_STATIC_LIBRARIES) <-- The .a that we built # $(TARGET_LIBGCC) <-- libgcc.a # $(PRIVATE_SHARED_LIBRARIES) <-- The .so that we built # $(PRIVATE_LDLIBS) <-- System .so # $(TARGET_CRTEND_O) <-- crtend.o # # For now the above are approximated for executables by adding # crtbegin.o to the end of the ldflags and 'crtend.o' to the end # of 'libraries'. # # The NDK Android shared library link step looks as follows: # $LDFLAGS # $(PRIVATE_OBJECTS) <-- The .o that we built # -l,--whole-archive # $(PRIVATE_WHOLE_STATIC_LIBRARIES) # -l,--no-whole-archive # $(PRIVATE_STATIC_LIBRARIES) <-- The .a that we built # $(TARGET_LIBGCC) <-- libgcc.a # $(PRIVATE_SHARED_LIBRARIES) <-- The .so that we built # $(PRIVATE_LDLIBS) <-- System .so # # For now, assume that whole static libraries are not needed. # # For both executables and shared libraries, add the proper # libgcc.a to the start of libraries which puts it in the # proper spot after .o and .a files get linked in. # # TODO: The proper thing to do longer-tem would be proper gyp # support for a custom link command line. ['_toolset=="target"', { 'cflags!': [ '-pthread', # Not supported by Android toolchain. ], 'cflags': [ '-ffunction-sections', '-funwind-tables', '-g', '-fstack-protector', '-fno-short-enums', '-finline-limit=64', '-Wa,--noexecstack', '<@(release_extra_cflags)', ], 'defines': [ 'ANDROID', '__GNU_SOURCE=1', # Necessary for clone() 'USE_STLPORT=1', '_STLP_USE_PTR_SPECIALIZATIONS=1', 'CHROME_BUILD_ID="<(chrome_build_id)"', ], 'ldflags!': [ '-pthread', # Not supported by Android toolchain. ], 'ldflags': [ '-Wl,--no-undefined', ], 'conditions': [ ['component=="static_library" and android_webview_build==0', { 'target_conditions': [ ['use_native_jni_exports==0', { # Use a linker version script to strip JNI exports from # binaries which have not specifically asked to use them. 'ldflags': [ '-Wl,--version-script=(_target_name).map', ], }, }], ], }], ['_mac_bundle', { 'xcode_settings': {'OTHER_LDFLAGS': ['-Wl,-ObjC']}, 'target_conditions': [ ['_type=="executable"', { 'conditions': [ ['asan==1', { 'postbuilds': [ { 'variables': { # Define copy_asan_dylib_path in a variable ending in # _path so that gyp understands it's a path and # performs proper relativization during dict merging. 'copy_asan_dylib_path': 'mac/copy_asan_runtime_dylib.sh', }, 'postbuild_name': 'Copy ASan runtime dylib', 'action': [ '<(copy_asan_dylib_path)', ], }, ], }], ], }], ], }], ], # target_conditions }, # target_defaults }], # OS=="mac" or OS=="ios" ['OS=="mac"', { 'target_defaults': { 'defines': [ # Prevent Mac OS X AssertMacros.h from defining macros that collide # with common names, like 'check', 'require', and 'verify'. # (Included by system header. Also exists on iOS but not included.) # http://opensource.apple.com/source/CarbonHeaders/CarbonHeaders-18.1/AssertMacros.h '__ASSERT_MACROS_DEFINE_VERSIONS_WITHOUT_UNDERSCORE=0', ], 'variables': { # These should end with %, but there seems to be a bug with % in # variables that are intended to be set to different values in # different targets, like these. 'mac_pie': 1, # Most executables can be position-independent. # Strip debugging symbols from the target. 'mac_strip': '<(mac_strip_release)', 'conditions': [ ['asan==1', { 'conditions': [ ['mac_want_real_dsym=="default"', { 'mac_real_dsym': 1, }, { 'mac_real_dsym': '<(mac_want_real_dsym)' }], ], }, { 'conditions': [ ['mac_want_real_dsym=="default"', { 'mac_real_dsym': 0, # Fake .dSYMs are fine in most cases. }, { 'mac_real_dsym': '<(mac_want_real_dsym)' }], ], }], ], }, 'xcode_settings': { 'GCC_DYNAMIC_NO_PIC': 'NO', # No -mdynamic-no-pic # (Equivalent to -fPIC) # MACOSX_DEPLOYMENT_TARGET maps to -mmacosx-version-min 'MACOSX_DEPLOYMENT_TARGET': '<(mac_deployment_target)', # Keep pch files below xcodebuild/. 'SHARED_PRECOMPS_DIR': '$(CONFIGURATION_BUILD_DIR)/SharedPrecompiledHeaders', 'OTHER_CFLAGS': [ # Someday this can be replaced by an 'GCC_STRICT_ALIASING': 'NO' # xcode_setting, but not until all downstream projects' mac bots are # using xcode >= 4.6, because that's when the default value of the # flag in the compiler switched. Pre-4.6, the value 'NO' for that # setting is a no-op as far as xcode is concerned, but the compiler # behaves differently based on whether -fno-strict-aliasing is # specified or not. '-fno-strict-aliasing', # See http://crbug.com/32204. ], }, 'target_conditions': [ ['_type=="executable"', { 'postbuilds': [ { # Arranges for data (heap) pages to be protected against # code execution when running on Mac OS X 10.7 ("Lion"), and # ensures that the position-independent executable (PIE) bit # is set for ASLR when running on Mac OS X 10.5 ("Leopard"). 'variables': { # Define change_mach_o_flags in a variable ending in _path # so that GYP understands it's a path and performs proper # relativization during dict merging. 'change_mach_o_flags_path': 'mac/change_mach_o_flags_from_xcode.sh', 'change_mach_o_flags_options%': [ ], 'target_conditions': [ ['mac_pie==0 or release_valgrind_build==1', { # Don't enable PIE if it's unwanted. It's unwanted if # the target specifies mac_pie=0 or if building for # Valgrind, because Valgrind doesn't understand slide. # See the similar mac_pie/release_valgrind_build check # below. 'change_mach_o_flags_options': [ '--no-pie', ], }], ], }, 'postbuild_name': 'Change Mach-O Flags', 'action': [ '<(change_mach_o_flags_path)', '>@(change_mach_o_flags_options)', ], }, ], 'target_conditions': [ ['mac_pie==1 and release_valgrind_build==0', { # Turn on position-independence (ASLR) for executables. When # PIE is on for the Chrome executables, the framework will # also be subject to ASLR. # Don't do this when building for Valgrind, because Valgrind # doesn't understand slide. TODO: Make Valgrind on Mac OS X # understand slide, and get rid of the Valgrind check. 'xcode_settings': { 'OTHER_LDFLAGS': [ '-Wl,-pie', # Position-independent executable (MH_PIE) ], }, }], ], }], ['(_type=="executable" or _type=="shared_library" or \ _type=="loadable_module") and mac_strip!=0', { 'target_conditions': [ ['mac_real_dsym == 1', { # To get a real .dSYM bundle produced by dsymutil, set the # debug information format to dwarf-with-dsym. Since # strip_from_xcode will not be used, set Xcode to do the # stripping as well. 'configurations': { 'Release_Base': { 'xcode_settings': { 'DEBUG_INFORMATION_FORMAT': 'dwarf-with-dsym', 'DEPLOYMENT_POSTPROCESSING': 'YES', 'STRIP_INSTALLED_PRODUCT': 'YES', 'conditions': [ # Only strip non-ASan builds. ['asan==0', { 'target_conditions': [ ['_type=="shared_library" or _type=="loadable_module"', { # The Xcode default is to strip debugging symbols # only (-S). Local symbols should be stripped as # well, which will be handled by -x. Xcode will # continue to insert -S when stripping even when # additional flags are added with STRIPFLAGS. 'STRIPFLAGS': '-x', }], # _type=="shared_library" or _type=="loadable_module" ], # target_conditions }, { # asan != 0 'STRIPFLAGS': '-S', }], ], }, # xcode_settings }, # configuration "Release" }, # configurations }, { # mac_real_dsym != 1 # To get a fast fake .dSYM bundle, use a post-build step to # produce the .dSYM and strip the executable. strip_from_xcode # only operates in the Release configuration. 'postbuilds': [ { 'variables': { # Define strip_from_xcode in a variable ending in _path # so that gyp understands it's a path and performs proper # relativization during dict merging. 'strip_from_xcode_path': 'mac/strip_from_xcode', }, 'postbuild_name': 'Strip If Needed', 'action': ['<(strip_from_xcode_path)'], }, ], # postbuilds }], # mac_real_dsym ], # target_conditions }], # (_type=="executable" or _type=="shared_library" or # _type=="loadable_module") and mac_strip!=0 ], # target_conditions }, # target_defaults }], # OS=="mac" ['OS=="ios"', { 'includes': [ 'ios/coverage.gypi', ], 'target_defaults': { 'xcode_settings' : { 'CLANG_CXX_LANGUAGE_STANDARD': 'c++11', 'conditions': [ # Older Xcodes do not support -Wno-deprecated-register, so pass an # additional flag to suppress the "unknown compiler option" error. # Restrict this flag to builds that are either compiling with Xcode # or compiling with Xcode's Clang. This will allow Ninja builds to # continue failing on unknown compiler options. # TODO(rohitrao): This flag is temporary and should be removed as # soon as the iOS bots are updated to use Xcode 5.1. ['clang_xcode==1', { 'WARNING_CFLAGS': [ '-Wno-unknown-warning-option', ], }], # Limit the valid architectures depending on "target_subarch". # This need to include the "arm" architectures but also the "x86" # ones (they are used when building for the simulator). ['target_subarch=="arm32"', { 'VALID_ARCHS': ['armv7', 'i386'], }], ['target_subarch=="arm64"', { 'VALID_ARCHS': ['arm64', 'x86_64'], }], ['target_subarch=="both"', { 'VALID_ARCHS': ['arm64', 'armv7', 'x86_64', 'i386'], }], ['use_system_libcxx==1', { 'target_conditions': [ # Only use libc++ when building target for iOS not when building # tools for the host (OS X) as Mac targets OS X SDK 10.6 which # does not support libc++. ['_toolset=="target"', { 'CLANG_CXX_LIBRARY': 'libc++', # -stdlib=libc++ }] ], }, { # The default for deployment target of 7.0+ is libc++, so force # the old behavior unless libc++ is enabled. 'CLANG_CXX_LIBRARY': 'libstdc++', # -stdlib=libstdc++ }], ], }, 'target_conditions': [ ['_toolset=="host"', { 'xcode_settings': { 'SDKROOT': 'macosx<(mac_sdk)', # -isysroot 'MACOSX_DEPLOYMENT_TARGET': '<(mac_deployment_target)', 'VALID_ARCHS': [ 'x86_64', ], 'ARCHS': [ 'x86_64', ], }, }], ['_toolset=="target"', { 'xcode_settings': { # This section should be for overriding host settings. But, # since we can't negate the iphone deployment target above, we # instead set it here for target only. 'IPHONEOS_DEPLOYMENT_TARGET': '<(ios_deployment_target)', 'ARCHS': ['$(ARCHS_STANDARD_INCLUDING_64_BIT)'], }, }], ['_type=="executable"', { 'configurations': { 'Release_Base': { 'xcode_settings': { 'DEPLOYMENT_POSTPROCESSING': 'YES', 'STRIP_INSTALLED_PRODUCT': 'YES', }, }, 'Debug_Base': { 'xcode_settings': { # Remove dSYM to reduce build time. 'DEBUG_INFORMATION_FORMAT': 'dwarf', }, }, }, 'xcode_settings': { 'conditions': [ ['chromium_ios_signing', { # iOS SDK wants everything for device signed. 'CODE_SIGN_IDENTITY[sdk=iphoneos*]': 'iPhone Developer', }, { 'CODE_SIGNING_REQUIRED': 'NO', 'CODE_SIGN_IDENTITY[sdk=iphoneos*]': '', }], ], }, }], ], # target_conditions }, # target_defaults }], # OS=="ios" ['OS=="win"', { 'target_defaults': { 'defines': [ '_WIN32_WINNT=0x0603', 'WINVER=0x0603', 'WIN32', '_WINDOWS', 'NOMINMAX', 'PSAPI_VERSION=1', '_CRT_RAND_S', 'CERT_CHAIN_PARA_HAS_EXTRA_FIELDS', 'WIN32_LEAN_AND_MEAN', '_ATL_NO_OPENGL', '_SECURE_ATL', # _HAS_EXCEPTIONS must match ExceptionHandling in msvs_settings. '_HAS_EXCEPTIONS=0', # Silence some warnings; we can't switch the the 'recommended' # versions as they're not available on old OSs. '_WINSOCK_DEPRECATED_NO_WARNINGS', ], 'conditions': [ ['buildtype=="Official"', { # In official builds, targets can self-select an optimization # level by defining a variable named 'optimize', and setting it # to one of # - "size", optimizes for minimal code size - the default. # - "speed", optimizes for speed over code size. # - "max", whole program optimization and link-time code # generation. This is very expensive and should be used # sparingly. 'variables': { 'optimize%': 'size', }, 'msvs_settings': { 'VCLinkerTool': { # Set /LTCG for the official builds. 'LinkTimeCodeGeneration': '1', 'AdditionalOptions': [ # Set the number of LTCG code-gen threads to eight. # The default is four. This gives a 5-10% link speedup. '/cgthreads:8', ], }, }, 'target_conditions': [ ['optimize=="size"', { 'msvs_settings': { 'VCCLCompilerTool': { # 1, optimizeMinSpace, Minimize Size (/O1) 'Optimization': '1', # 2, favorSize - Favor small code (/Os) 'FavorSizeOrSpeed': '2', }, }, }, ], ['optimize=="speed"', { 'msvs_settings': { 'VCCLCompilerTool': { # 2, optimizeMaxSpeed, Maximize Speed (/O2) 'Optimization': '2', # 1, favorSpeed - Favor fast code (/Ot) 'FavorSizeOrSpeed': '1', }, }, }, ], ['optimize=="max"', { # Disable Warning 4702 ("Unreachable code") for the WPO/PGO # builds. Probably anything that this would catch that # wouldn't be caught in a normal build isn't going to # actually be a bug, so the incremental value of C4702 for # PGO builds is likely very small. 'msvs_disabled_warnings': [ 4702 ], 'msvs_settings': { 'VCCLCompilerTool': { # 2, optimizeMaxSpeed, Maximize Speed (/O2) 'Optimization': '2', # 1, favorSpeed - Favor fast code (/Ot) 'FavorSizeOrSpeed': '1', # This implies link time code generation. 'WholeProgramOptimization': 'true', }, }, }, ], ], }, ], ['msvs_xtree_patched!=1', { # If xtree hasn't been patched, then we disable C4702. Otherwise, # it's enabled. This will generally only be true for system-level # installed Express users. 'msvs_disabled_warnings': [ 4702, ], }], ], 'msvs_system_include_dirs': [ '<(windows_sdk_path)/Include/shared', '<(windows_sdk_path)/Include/um', '<(windows_sdk_path)/Include/winrt', '$(VSInstallDir)/VC/atlmfc/include', ], 'msvs_cygwin_shell': 0, 'msvs_disabled_warnings': [ # C4127: conditional expression is constant # This warning can in theory catch dead code and other problems, but # triggers in far too many desirable cases where the conditional # expression is either set by macros or corresponds some legitimate # compile-time constant expression (due to constant template args, # conditionals comparing the sizes of different types, etc.). Some of # these can be worked around, but it's not worth it. 4127, # C4351: new behavior: elements of array 'array' will be default # initialized # This is a silly "warning" that basically just alerts you that the # compiler is going to actually follow the language spec like it's # supposed to, instead of not following it like old buggy versions # did. There's absolutely no reason to turn this on. 4351, # C4355: 'this': used in base member initializer list # It's commonly useful to pass |this| to objects in a class' # initializer list. While this warning can catch real bugs, most of # the time the constructors in question don't attempt to call methods # on the passed-in pointer (until later), and annotating every legit # usage of this is simply more hassle than the warning is worth. 4355, # C4503: 'identifier': decorated name length exceeded, name was # truncated # This only means that some long error messages might have truncated # identifiers in the presence of lots of templates. It has no effect # on program correctness and there's no real reason to waste time # trying to prevent it. 4503, # C4611: interaction between 'function' and C++ object destruction is # non-portable # This warning is unavoidable when using e.g. setjmp/longjmp. MSDN # suggests using exceptions instead of setjmp/longjmp for C++, but # Chromium code compiles without exception support. We therefore have # to use setjmp/longjmp for e.g. JPEG decode error handling, which # means we have to turn off this warning (and be careful about how # object destruction happens in such cases). 4611, # TODO(maruel): These warnings are level 4. They will be slowly # removed as code is fixed. 4100, # Unreferenced formal parameter 4121, # Alignment of a member was sensitive to packing 4244, # Conversion from 'type1' to 'type2', possible loss of data 4481, # Nonstandard extension used: override specifier 'keyword' 4505, # Unreferenced local function has been removed 4510, # Default constructor could not be generated 4512, # Assignment operator could not be generated 4610, # Object can never be instantiated 4996, # 'X': was declared deprecated (for GetVersionEx). ], 'msvs_settings': { 'VCCLCompilerTool': { 'AdditionalOptions': ['/MP'], 'MinimalRebuild': 'false', 'BufferSecurityCheck': 'true', 'EnableFunctionLevelLinking': 'true', 'RuntimeTypeInfo': 'false', 'WarningLevel': '4', 'WarnAsError': 'true', 'DebugInformationFormat': '3', # ExceptionHandling must match _HAS_EXCEPTIONS above. 'ExceptionHandling': '0', }, 'VCLibrarianTool': { 'AdditionalOptions': ['/ignore:4221'], 'AdditionalLibraryDirectories': [ '<(windows_sdk_path)/Lib/win8/um/x86', ], }, 'VCLinkerTool': { 'AdditionalDependencies': [ 'wininet.lib', 'dnsapi.lib', 'version.lib', 'msimg32.lib', 'ws2_32.lib', 'usp10.lib', 'psapi.lib', 'dbghelp.lib', 'winmm.lib', 'shlwapi.lib', ], 'AdditionalLibraryDirectories': [ '<(windows_sdk_path)/Lib/win8/um/x86', ], 'GenerateDebugInformation': 'true', 'MapFileName': '$(OutDir)\\$(TargetName).map', 'ImportLibrary': '$(OutDir)\\lib\\$(TargetName).lib', 'FixedBaseAddress': '1', # SubSystem values: # 0 == not set # 1 == /SUBSYSTEM:CONSOLE # 2 == /SUBSYSTEM:WINDOWS # Most of the executables we'll ever create are tests # and utilities with console output. 'SubSystem': '1', }, 'VCMIDLTool': { 'GenerateStublessProxies': 'true', 'TypeLibraryName': '$(InputName).tlb', 'OutputDirectory': '$(IntDir)', 'HeaderFileName': '$(InputName).h', 'DLLDataFileName': '$(InputName).dlldata.c', 'InterfaceIdentifierFileName': '$(InputName)_i.c', 'ProxyFileName': '$(InputName)_p.c', }, 'VCResourceCompilerTool': { 'Culture' : '1033', 'AdditionalIncludeDirectories': [ '<(DEPTH)', '<(SHARED_INTERMEDIATE_DIR)', ], }, 'target_conditions': [ ['_type=="executable"', { 'VCManifestTool': { 'EmbedManifest': 'true', }, }], ['_type=="executable" and ">(win_exe_compatibility_manifest)"!=""', { 'VCManifestTool': { 'AdditionalManifestFiles': [ '>(win_exe_compatibility_manifest)', ], }, }], ], 'conditions': [ # Building with Clang on Windows is a work in progress and very # experimental. See crbug.com/82385. ['clang==1', { 'VCCLCompilerTool': { 'AdditionalOptions': [ '-fmsc-version=1800', # Many files use intrinsics without including this header. # TODO(hans): Fix those files, or move this to sub-GYPs. '/FIIntrin.h', # TODO(hans): Make this list shorter eventually. '-Qunused-arguments', '-Wno-c++11-compat-deprecated-writable-strings', '-Wno-deprecated-declarations', '-Wno-empty-body', '-Wno-enum-conversion', '-Wno-extra-tokens', '-Wno-ignored-attributes', '-Wno-incompatible-pointer-types', '-Wno-int-to-void-pointer-cast', '-Wno-invalid-noreturn', '-Wno-logical-op-parentheses', '-Wno-microsoft', '-Wno-missing-braces', '-Wno-missing-declarations', '-Wno-msvc-include', '-Wno-null-dereference', '-Wno-overloaded-virtual', '-Wno-parentheses', '-Wno-pointer-sign', '-Wno-reorder', '-Wno-return-type-c-linkage', '-Wno-self-assign', '-Wno-sometimes-uninitialized', '-Wno-switch', '-Wno-tautological-compare', '-Wno-unknown-pragmas', '-Wno-unsequenced', '-Wno-unused-function', '-Wno-unused-private-field', '-Wno-unused-value', '-Wno-unused-variable', '-Wno-unused-local-typedef', # http://crbug.com/411648 '-Wno-inconsistent-missing-override', #http://crbug.com/428099 ], }, }], ['clang==1 and target_arch=="ia32"', { 'VCCLCompilerTool': { 'WarnAsError': 'false', 'AdditionalOptions': [ '/fallback', ], }, }], ], }, }, }], ['disable_nacl==1', { 'target_defaults': { 'defines': [ 'DISABLE_NACL', ], }, }], ['OS=="win" and msvs_use_common_linker_extras', { 'target_defaults': { 'msvs_settings': { 'VCLinkerTool': { 'DelayLoadDLLs': [ 'dbghelp.dll', 'dwmapi.dll', 'shell32.dll', 'uxtheme.dll', ], }, }, 'configurations': { 'x86_Base': { 'msvs_settings': { 'VCLinkerTool': { 'AdditionalOptions': [ '/safeseh', '/dynamicbase', '/ignore:4199', '/ignore:4221', '/nxcompat', ], }, 'conditions': [ ['syzyasan==0', { 'VCLinkerTool': { 'AdditionalOptions': ['/largeaddressaware'], }, }], ['asan==1', { # TODO(asan/win): Move this down into the general # win-target_defaults section once the 64-bit asan runtime # exists. See crbug.com/345874. 'VCCLCompilerTool': { 'AdditionalOptions': [ '-fsanitize=address', '-fsanitize-blacklist=<(PRODUCT_DIR)/../../tools/memory/asan/blacklist_win.txt', ], 'AdditionalIncludeDirectories': [ # MSVC needs to be able to find the sanitizer headers when # invoked via /fallback. This is critical for using macros # like ASAN_UNPOISON_MEMORY_REGION in files where we fall # back. '<(DEPTH)/<(make_clang_dir)/lib/clang/3.7.0/include_sanitizer', ], }, 'VCLinkerTool': { 'AdditionalLibraryDirectories': [ # TODO(hans): If make_clang_dir is absolute, this breaks. '<(DEPTH)/<(make_clang_dir)/lib/clang/3.7.0/lib/windows', ], }, 'target_conditions': [ ['component=="shared_library"', { 'VCLinkerTool': { 'AdditionalDependencies': [ 'clang_rt.asan_dynamic-i386.lib', 'clang_rt.asan_dynamic_runtime_thunk-i386.lib', ], }, }], ['_type=="executable" and component=="static_library"', { 'VCLinkerTool': { 'AdditionalDependencies': [ 'clang_rt.asan-i386.lib', ], }, }], ['(_type=="shared_library" or _type=="loadable_module") and component=="static_library"', { 'VCLinkerTool': { 'AdditionalDependencies': [ 'clang_rt.asan_dll_thunk-i386.lib', ], }, }], ], }], ], }, }, 'x64_Base': { 'msvs_settings': { 'VCLinkerTool': { 'AdditionalOptions': [ # safeseh is not compatible with x64 '/dynamicbase', '/ignore:4199', '/ignore:4221', '/nxcompat', ], }, }, }, }, }, }], ['enable_new_npdevice_api==1', { 'target_defaults': { 'defines': [ 'ENABLE_NEW_NPDEVICE_API', ], }, }], # Don't warn about the "typedef 'foo' locally defined but not used" # for gcc 4.8 and higher. # TODO: remove this flag once all builds work. See crbug.com/227506 ['gcc_version>=48 and clang==0', { 'target_defaults': { 'cflags': [ '-Wno-unused-local-typedefs', ], }, }], ['gcc_version>=48 and clang==0 and host_clang==1', { 'target_defaults': { 'target_conditions': [ ['_toolset=="host"', { 'cflags!': [ '-Wno-unused-local-typedefs' ]}], ], }, }], # In the android webview build, force host targets to be compiled with clang # as the hermetic host gcc is very old on some platforms. This is already # the default on the current development version of AOSP but we force it # here in case we need to compile against an older release version. We also # explicitly set it to false for target binaries to avoid causing problems # for the work to enable clang by default in AOSP. We also force the use of # libstdc++ on host as peculiarities of the android gyp backend mean that # using libc++ doesn't work, and Chromium doesn't yet require a more modern # C++ library. ['android_webview_build==1', { 'target_defaults': { 'target_conditions': [ ['_toolset=="host"', { 'aosp_build_settings': { 'LOCAL_CLANG': 'true', 'LOCAL_CXX_STL': 'libstdc++', }, }, { # else: _toolset != "host" 'aosp_build_settings': { 'LOCAL_CLANG': 'false', }, }], ], }, }], # We need a special case to handle the android webview build on mac because # the host gcc there doesn't accept this flag, but the target gcc may # require it. ['gcc_version>=48 and android_webview_build==1 and host_os=="mac"', { 'target_defaults': { 'target_conditions': [ ['_toolset=="host"', { 'cflags!': [ '-Wno-unused-local-typedefs', ], }], ], }, }], ['clang==1 and ((OS!="mac" and OS!="ios") or clang_xcode==0) ' 'and OS!="win"', { 'make_global_settings': [ ['CC', '<(make_clang_dir)/bin/clang'], ['CXX', '<(make_clang_dir)/bin/clang++'], ['CC.host', '$(CC)'], ['CXX.host', '$(CXX)'], ], }], ['clang==1 and OS=="win"', { 'make_global_settings': [ # On Windows, gyp's ninja generator only looks at CC. ['CC', '<(make_clang_dir)/bin/clang-cl'], ], }], ['use_lld==1 and OS=="win"', { 'make_global_settings': [ # Limited to Windows because lld-link is the driver that is compatible # to link.exe. ['LD', '<(make_clang_dir)/bin/lld-link'], ], }], ['OS=="android" and clang==0', { # Hardcode the compiler names in the Makefile so that # it won't depend on the environment at make time. 'make_global_settings': [ ['CC', '