Index: src/client/windows/build/common.gypi |
=================================================================== |
--- src/client/windows/build/common.gypi (revision 0) |
+++ src/client/windows/build/common.gypi (revision 0) |
@@ -0,0 +1,1343 @@ |
+# Copyright (c) 2010, Google Inc. |
+# All rights reserved. |
+# |
+# Redistribution and use in source and binary forms, with or without |
+# modification, are permitted provided that the following conditions are |
+# met: |
+# |
+# * Redistributions of source code must retain the above copyright |
+# notice, this list of conditions and the following disclaimer. |
+# * Redistributions in binary form must reproduce the above |
+# copyright notice, this list of conditions and the following disclaimer |
+# in the documentation and/or other materials provided with the |
+# distribution. |
+# * Neither the name of Google Inc. nor the names of its |
+# contributors may be used to endorse or promote products derived from |
+# this software without specific prior written permission. |
+# |
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
+# "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 THE COPYRIGHT |
+# OWNER 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 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
+ |
+# IMPORTANT: |
+# Please don't directly include this file if you are building via gyp_chromium, |
+# since gyp_chromium is automatically forcing its inclusion. |
+{ |
+ 'variables': { |
+ # .gyp files or targets should set chromium_code to 1 if they build |
+ # Chromium-specific code, as opposed to external code. This variable is |
+ # used to control such things as the set of warnings to enable, and |
+ # whether warnings are treated as errors. |
+ 'chromium_code%': 0, |
+ |
+ # Variables expected to be overriden on the GYP command line (-D) or by |
+ # ~/.gyp/include.gypi. |
+ |
+ # Putting a variables dict inside another variables dict looks kind of |
+ # weird. This is done so that "branding" and "buildtype" 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': { |
+ # Override branding to select the desired branding flavor. |
+ 'branding%': 'Chromium', |
+ |
+ # Override buildtype to select the desired build flavor. |
+ # Dev - everyday build for development/testing |
+ # Official - release build (generally implies additional processing) |
+ # TODO(mmoss) Once 'buildtype' is fully supported (e.g. Windows gyp |
+ # conversion is done), some of the things which are now controlled by |
+ # 'branding', such as symbol generation, will need to be refactored based |
+ # on 'buildtype' (i.e. we don't care about saving symbols for non-Official |
+ # builds). |
+ 'buildtype%': 'Dev', |
+ |
+ 'variables': { |
+ # Compute the architecture that we're building on. |
+ 'conditions': [ |
+ [ 'OS=="linux" or OS=="freebsd" or OS=="openbsd"', { |
+ # This handles the Linux platforms we generally deal with. Anything |
+ # else gets passed through, which probably won't work very well; such |
+ # hosts should pass an explicit target_arch to gyp. |
+ 'host_arch%': |
+ '<!(uname -m | sed -e "s/i.86/ia32/;s/x86_64/x64/;s/amd64/x64/;s/arm.*/arm/")', |
+ }, { # OS!="linux" |
+ 'host_arch%': 'ia32', |
+ }], |
+ ], |
+ |
+ # Whether we're building a ChromeOS build. We set the initial |
+ # value at this level of nesting so it's available for the |
+ # toolkit_views test below. |
+ 'chromeos%': '0', |
+ }, |
+ |
+ # Set default value of toolkit_views on for Windows and Chrome OS. |
+ # We set it at this level of nesting so the value is available for |
+ # other conditionals below. |
+ 'conditions': [ |
+ ['OS=="win" or chromeos==1', { |
+ 'toolkit_views%': 1, |
+ }, { |
+ 'toolkit_views%': 0, |
+ }], |
+ ], |
+ |
+ 'host_arch%': '<(host_arch)', |
+ |
+ # Default architecture we're building for is the architecture we're |
+ # building on. |
+ 'target_arch%': '<(host_arch)', |
+ |
+ # We do want to build Chromium with Breakpad support in certain |
+ # situations. I.e. for Chrome bot. |
+ 'linux_chromium_breakpad%': 0, |
+ # And if we want to dump symbols. |
+ 'linux_chromium_dump_symbols%': 0, |
+ # Also see linux_strip_binary below. |
+ |
+ # Copy conditionally-set chromeos variable out one scope. |
+ 'chromeos%': '<(chromeos)', |
+ |
+ # This variable tells WebCore.gyp and JavaScriptCore.gyp whether they are |
+ # are built under a chromium full build (1) or a webkit.org chromium |
+ # build (0). |
+ 'inside_chromium_build%': 1, |
+ |
+ # Set to 1 to enable fast builds. It disables debug info for fastest |
+ # compilation. |
+ 'fastbuild%': 0, |
+ |
+ # Set to 1 compile with -fPIC cflag on linux. This is a must for shared |
+ # libraries on linux x86-64 and arm. |
+ 'linux_fpic%': 0, |
+ |
+ # Python version. |
+ 'python_ver%': '2.5', |
+ |
+ # Set ARM-v7 compilation flags |
+ 'armv7%': 0, |
+ |
+ # Set Neon compilation flags (only meaningful if armv7==1). |
+ 'arm_neon%': 1, |
+ |
+ # The system root for cross-compiles. Default: none. |
+ 'sysroot%': '', |
+ |
+ # On Linux, we build with sse2 for Chromium builds. |
+ 'disable_sse2%': 0, |
+ }, |
+ |
+ # Define branding and buildtype on the basis of their settings within the |
+ # variables sub-dict above, unless overridden. |
+ 'branding%': '<(branding)', |
+ 'buildtype%': '<(buildtype)', |
+ 'target_arch%': '<(target_arch)', |
+ 'host_arch%': '<(host_arch)', |
+ 'toolkit_views%': '<(toolkit_views)', |
+ 'chromeos%': '<(chromeos)', |
+ 'inside_chromium_build%': '<(inside_chromium_build)', |
+ 'fastbuild%': '<(fastbuild)', |
+ 'linux_fpic%': '<(linux_fpic)', |
+ 'python_ver%': '<(python_ver)', |
+ 'armv7%': '<(armv7)', |
+ 'arm_neon%': '<(arm_neon)', |
+ 'sysroot%': '<(sysroot)', |
+ 'disable_sse2%': '<(disable_sse2)', |
+ |
+ # 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, |
+ |
+ # Mac OS X SDK and deployment target support. |
+ # The SDK identifies the version of the system headers that will be used, |
+ # and corresponds to the MAC_OS_X_VERSION_MAX_ALLOWED compile-time macro. |
+ # "Maximum allowed" refers to the operating system version whose APIs are |
+ # available in the headers. |
+ # The deployment target identifies the minimum system version that the |
+ # built products are expected to function on. It corresponds to the |
+ # MAC_OS_X_VERSION_MIN_REQUIRED compile-time macro. |
+ # To ensure these macros are available, #include <AvailabilityMacros.h>. |
+ # 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.5 SDK and sets the |
+ # deployment target to 10.5. Other projects, such as O3D, may override |
+ # these defaults. |
+ 'mac_sdk%': '10.5', |
+ 'mac_deployment_target%': '10.5', |
+ |
+ # Set to 1 to enable code coverage. In addition to build changes |
+ # (e.g. extra CFLAGS), also creates a new target in the src/chrome |
+ # project file called "coverage". |
+ # Currently ignored on Windows. |
+ 'coverage%': 0, |
+ |
+ # Overridable specification for potential use of alternative |
+ # JavaScript engines. |
+ 'javascript_engine%': 'v8', |
+ |
+ # 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, # 0 = shim allocator via libcmt; 1 = msvcrt |
+ |
+ # To do a shared build on linux we need to be able to choose between type |
+ # static_library and shared_library. We default to doing a static build |
+ # but you can override this with "gyp -Dlibrary=shared_library" or you |
+ # can add the following line (without the #) to ~/.gyp/include.gypi |
+ # {'variables': {'library': 'shared_library'}} |
+ # to compile as shared by default |
+ 'library%': 'static_library', |
+ |
+ # Whether usage of OpenMAX is enabled. |
+ 'enable_openmax%': 0, |
+ |
+ # 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', |
+ |
+ # This is the location of the sandbox binary. Chrome looks for this before |
+ # running the zygote process. If found, and SUID, it will be used to |
+ # sandbox the zygote process and, thus, all renderer processes. |
+ 'linux_sandbox_path%': '', |
+ |
+ # Set this to true to enable SELinux support. |
+ 'selinux%': 0, |
+ |
+ # Strip the binary after dumping symbols. |
+ 'linux_strip_binary%': 0, |
+ |
+ # Enable TCMalloc. |
+ 'linux_use_tcmalloc%': 1, |
+ |
+ # Disable TCMalloc's debugallocation. |
+ 'linux_use_debugallocation%': 0, |
+ |
+ # Disable TCMalloc's heapchecker. |
+ 'linux_use_heapchecker%': 0, |
+ |
+ # Set to 1 to turn on seccomp sandbox by default. |
+ # (Note: this is ignored for official builds.) |
+ 'linux_use_seccomp_sandbox%': 0, |
+ |
+ # Set to select the Title Case versions of strings in GRD files. |
+ 'use_titlecase_in_grd_files%': 0, |
+ |
+ # Used to disable Native Client at compile time, for platforms where it |
+ # isn't supported |
+ 'disable_nacl%': 0, |
+ |
+ # Set Thumb compilation flags. |
+ 'arm_thumb%': 0, |
+ |
+ # Set ARM fpu compilation flags (only meaningful if armv7==1 and |
+ # arm_neon==0). |
+ 'arm_fpu%': 'vfpv3', |
+ |
+ # Enable new NPDevice API. |
+ 'enable_new_npdevice_api%': 0, |
+ |
+ 'conditions': [ |
+ ['OS=="linux" or OS=="freebsd" or OS=="openbsd"', { |
+ # This will set gcc_version to XY if you are running gcc X.Y.*. |
+ # This is used to tweak build flags for gcc 4.4. |
+ 'gcc_version%': '<!(python <(DEPTH)/build/compiler_version.py)', |
+ # Figure out the python architecture to decide if we build pyauto. |
+ 'python_arch%': '<!(<(DEPTH)/build/linux/python_arch.sh <(sysroot)/usr/lib/libpython<(python_ver).so.1.0)', |
+ 'conditions': [ |
+ ['branding=="Chrome" or linux_chromium_breakpad==1', { |
+ 'linux_breakpad%': 1, |
+ }, { |
+ 'linux_breakpad%': 0, |
+ }], |
+ # All Chrome builds have breakpad symbols, but only process the |
+ # symbols from official builds. |
+ # TODO(mmoss) dump_syms segfaults on x64. Enable once dump_syms and |
+ # crash server handle 64-bit symbols. |
+ ['linux_chromium_dump_symbols==1 or ' |
+ '(branding=="Chrome" and buildtype=="Official" and ' |
+ 'target_arch=="ia32")', { |
+ 'linux_dump_symbols%': 1, |
+ }, { |
+ 'linux_dump_symbols%': 0, |
+ }], |
+ ['toolkit_views==0', { |
+ # GTK wants Title Case strings |
+ 'use_titlecase_in_grd_files%': 1, |
+ }], |
+ ], |
+ }], # OS=="linux" or OS=="freebsd" or OS=="openbsd" |
+ ['OS=="mac"', { |
+ # Mac wants Title Case strings |
+ 'use_titlecase_in_grd_files%': 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', |
+ }], |
+ |
+ # Feature variables for enabling Mac Breakpad and Keystone auto-update |
+ # support. Both features are on by default in official builds with |
+ # Chrome branding. |
+ ['branding=="Chrome" and buildtype=="Official"', { |
+ 'mac_breakpad%': 1, |
+ 'mac_keystone%': 1, |
+ }, { # else: branding!="Chrome" or buildtype!="Official" |
+ 'mac_breakpad%': 0, |
+ 'mac_keystone%': 0, |
+ }], |
+ ], |
+ }], # OS=="mac" |
+ # Whether to use multiple cores to compile with visual studio. This is |
+ # optional because it sometimes causes corruption on VS 2005. |
+ # It is on by default on VS 2008 and off on VS 2005. |
+ ['OS=="win"', { |
+ 'conditions': [ |
+ ['MSVS_VERSION=="2005"', { |
+ 'msvs_multi_core_compile%': 0, |
+ },{ |
+ 'msvs_multi_core_compile%': 1, |
+ }], |
+ # Don't do incremental linking for large modules on 32-bit. |
+ ['MSVS_OS_BITS==32', { |
+ 'msvs_large_module_debug_link_mode%': '1', # No |
+ },{ |
+ 'msvs_large_module_debug_link_mode%': '2', # Yes |
+ }], |
+ ], |
+ 'nacl_win64_defines': [ |
+ # This flag is used to minimize dependencies when building |
+ # Native Client loader for 64-bit Windows. |
+ 'NACL_WIN64', |
+ ], |
+ }], |
+ # Compute based on OS and target architecture whether the GPU |
+ # plugin / process is supported. |
+ [ 'OS=="win" or (OS=="linux" and target_arch!="arm") or OS=="mac"', { |
+ # Enable a variable used elsewhere throughout the GYP files to determine |
+ # whether to compile in the sources for the GPU plugin / process. |
+ 'enable_gpu%': 1, |
+ }, { # GPU plugin not supported |
+ 'enable_gpu%': 0, |
+ }], |
+ # Compute based on OS, target architecture and device whether GLES |
+ # is supported |
+ [ 'OS=="linux" and target_arch=="arm" and chromeos==1', { |
+ # Enable a variable used elsewhere throughout the GYP files to determine |
+ # whether to compile in the sources for the GLES support. |
+ 'enable_gles%': 1, |
+ }, { # GLES not supported |
+ 'enable_gles%': 0, |
+ }], |
+ ], |
+ |
+ # NOTE: When these end up in the Mac bundle, we need to replace '-' for '_' |
+ # so Cocoa is happy (http://crbug.com/20441). |
+ 'locales': [ |
+ 'am', 'ar', 'bg', 'bn', 'ca', 'cs', 'da', 'de', 'el', 'en-GB', |
+ 'en-US', 'es-419', 'es', 'et', 'fi', 'fil', 'fr', 'gu', 'he', |
+ 'hi', 'hr', 'hu', 'id', 'it', 'ja', 'kn', 'ko', 'lt', 'lv', |
+ 'ml', 'mr', 'nb', 'nl', 'pl', 'pt-BR', 'pt-PT', 'ro', 'ru', |
+ 'sk', 'sl', 'sr', 'sv', 'sw', 'ta', 'te', 'th', 'tr', 'uk', |
+ 'vi', 'zh-CN', 'zh-TW', |
+ ], |
+ }, |
+ 'target_defaults': { |
+ 'variables': { |
+ # The condition that operates on chromium_code is in a target_conditions |
+ # section, and will not have access to the default fallback value of |
+ # chromium_code at the top of this file, or to the chromium_code |
+ # variable placed at the root variables scope of .gyp files, because |
+ # those variables are not set at target scope. As a workaround, |
+ # if chromium_code is not set at target scope, define it in target scope |
+ # to contain whatever value it has during early variable expansion. |
+ # That's enough to make it available during target conditional |
+ # processing. |
+ 'chromium_code%': '<(chromium_code)', |
+ |
+ # See http://gcc.gnu.org/onlinedocs/gcc-4.4.2/gcc/Optimize-Options.html |
+ 'mac_release_optimization%': '3', # Use -O3 unless overridden |
+ 'mac_debug_optimization%': '0', # Use -O0 unless overridden |
+ # See http://msdn.microsoft.com/en-us/library/aa652360(VS.71).aspx |
+ 'win_release_Optimization%': '2', # 2 = /Os |
+ 'win_debug_Optimization%': '0', # 0 = /Od |
+ # See http://msdn.microsoft.com/en-us/library/aa652367(VS.71).aspx |
+ 'win_release_RuntimeLibrary%': '0', # 0 = /MT (nondebug static) |
+ 'win_debug_RuntimeLibrary%': '1', # 1 = /MTd (debug static) |
+ |
+ 'release_extra_cflags%': '', |
+ 'debug_extra_cflags%': '', |
+ 'release_valgrind_build%': 0, |
+ }, |
+ 'conditions': [ |
+ ['branding=="Chrome"', { |
+ 'defines': ['GOOGLE_CHROME_BUILD'], |
+ }, { # else: branding!="Chrome" |
+ 'defines': ['CHROMIUM_BUILD'], |
+ }], |
+ ['toolkit_views==1', { |
+ 'defines': ['TOOLKIT_VIEWS=1'], |
+ }], |
+ ['chromeos==1', { |
+ 'defines': ['OS_CHROMEOS=1'], |
+ }], |
+ ['fastbuild!=0', { |
+ 'conditions': [ |
+ # Finally, for Windows, we simply turn on profiling. |
+ ['OS=="win"', { |
+ 'msvs_settings': { |
+ 'VCLinkerTool': { |
+ 'GenerateDebugInformation': 'false', |
+ }, |
+ 'VCCLCompilerTool': { |
+ 'DebugInformationFormat': '0', |
+ } |
+ } |
+ }, { # else: OS != "win" |
+ 'cflags': [ '-g1' ], |
+ }], |
+ ], # conditions for fastbuild. |
+ }], # fastbuild!=0 |
+ ['selinux==1', { |
+ 'defines': ['CHROMIUM_SELINUX=1'], |
+ }], |
+ ['win_use_allocator_shim==0', { |
+ 'conditions': [ |
+ ['OS=="win"', { |
+ 'defines': ['NO_TCMALLOC'], |
+ }], |
+ ], |
+ }], |
+ ['enable_gpu==1', { |
+ 'defines': [ |
+ 'ENABLE_GPU=1', |
+ ], |
+ }], |
+ ['enable_gles==1', { |
+ 'defines': [ |
+ 'ENABLE_GLES=1', |
+ ], |
+ }], |
+ ['coverage!=0', { |
+ 'conditions': [ |
+ ['OS=="mac"', { |
+ 'xcode_settings': { |
+ 'GCC_INSTRUMENT_PROGRAM_FLOW_ARCS': 'YES', # -fprofile-arcs |
+ 'GCC_GENERATE_TEST_COVERAGE_FILES': 'YES', # -ftest-coverage |
+ }, |
+ # Add -lgcov for types executable, shared_library, and |
+ # loadable_module; not for static_library. |
+ # This is a delayed conditional. |
+ 'target_conditions': [ |
+ ['_type!="static_library"', { |
+ 'xcode_settings': { 'OTHER_LDFLAGS': [ '-lgcov' ] }, |
+ }], |
+ ], |
+ }], |
+ # Linux gyp (into scons) doesn't like target_conditions? |
+ # TODO(???): track down why 'target_conditions' doesn't work |
+ # on Linux gyp into scons like it does on Mac gyp into xcodeproj. |
+ ['OS=="linux"', { |
+ 'cflags': [ '-ftest-coverage', |
+ '-fprofile-arcs' ], |
+ 'link_settings': { 'libraries': [ '-lgcov' ] }, |
+ }], |
+ # Finally, for Windows, we simply turn on profiling. |
+ ['OS=="win"', { |
+ 'msvs_settings': { |
+ 'VCLinkerTool': { |
+ 'Profile': 'true', |
+ }, |
+ 'VCCLCompilerTool': { |
+ # /Z7, not /Zi, so coverage is happyb |
+ 'DebugInformationFormat': '1', |
+ 'AdditionalOptions': ['/Yd'], |
+ } |
+ } |
+ }], # OS==win |
+ ], # conditions for coverage |
+ }], # coverage!=0 |
+ ], # conditions for 'target_defaults' |
+ 'target_conditions': [ |
+ ['chromium_code==0', { |
+ 'conditions': [ |
+ [ 'OS=="linux" or OS=="freebsd" or OS=="openbsd"', { |
+ 'cflags!': [ |
+ '-Wall', |
+ '-Wextra', |
+ '-Werror', |
+ ], |
+ }], |
+ [ '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': { |
+ 'WarnAsError': 'false', |
+ 'Detect64BitPortabilityProblems': 'false', |
+ }, |
+ }, |
+ }], |
+ [ 'OS=="mac"', { |
+ 'xcode_settings': { |
+ 'GCC_TREAT_WARNINGS_AS_ERRORS': 'NO', |
+ 'WARNING_CFLAGS!': ['-Wall'], |
+ }, |
+ }], |
+ ], |
+ }, { |
+ # In Chromium code, we define __STDC_FORMAT_MACROS in order to get the |
+ # C99 macros on Mac and Linux. |
+ 'defines': [ |
+ '__STDC_FORMAT_MACROS', |
+ ], |
+ 'conditions': [ |
+ ['OS!="win"', { |
+ 'sources/': [ ['exclude', '_win(_unittest)?\\.cc$'], |
+ ['exclude', '/win/'], |
+ ['exclude', '/win_[^/]*\\.cc$'] ], |
+ }], |
+ ['OS!="mac"', { |
+ 'sources/': [ ['exclude', '_(cocoa|mac)(_unittest)?\\.cc$'], |
+ ['exclude', '/(cocoa|mac)/'], |
+ ['exclude', '\.mm?$' ] ], |
+ }], |
+ ['OS!="linux" and OS!="freebsd" and OS!="openbsd"', { |
+ 'sources/': [ |
+ ['exclude', '_(chromeos|gtk|x|x11|xdg)(_unittest)?\\.cc$'], |
+ ['exclude', '/gtk/'], |
+ ['exclude', '/(gtk|x11)_[^/]*\\.cc$'], |
+ ], |
+ }], |
+ ['OS!="linux"', { |
+ 'sources/': [ |
+ ['exclude', '_linux(_unittest)?\\.cc$'], |
+ ['exclude', '/linux/'], |
+ ], |
+ }], |
+ # We use "POSIX" to refer to all non-Windows operating systems. |
+ ['OS=="win"', { |
+ 'sources/': [ ['exclude', '_posix\\.cc$'] ], |
+ }], |
+ # Though Skia is conceptually shared by Linux and Windows, |
+ # the only _skia files in our tree are Linux-specific. |
+ ['OS!="linux" and OS!="freebsd" and OS!="openbsd"', { |
+ 'sources/': [ ['exclude', '_skia\\.cc$'] ], |
+ }], |
+ ['chromeos!=1', { |
+ 'sources/': [ ['exclude', '_chromeos\\.cc$'] ] |
+ }], |
+ ['toolkit_views==0', { |
+ 'sources/': [ ['exclude', '_views\\.cc$'] ] |
+ }], |
+ ], |
+ }], |
+ ], # 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': '$(SolutionDir)$(ConfigurationName)', |
+ 'IntermediateDirectory': '$(OutDir)\\obj\\$(ProjectName)', |
+ 'CharacterSet': '1', |
+ }, |
+ }, |
+ 'x86_Base': { |
+ 'abstract': 1, |
+ 'msvs_settings': { |
+ 'VCLinkerTool': { |
+ 'TargetMachine': '1', |
+ }, |
+ }, |
+ 'msvs_configuration_platform': 'Win32', |
+ }, |
+ 'x64_Base': { |
+ 'abstract': 1, |
+ 'msvs_configuration_platform': 'x64', |
+ 'msvs_settings': { |
+ 'VCLinkerTool': { |
+ 'TargetMachine': '17', # x86 - 64 |
+ 'AdditionalLibraryDirectories!': |
+ ['<(DEPTH)/third_party/platformsdk_win7/files/Lib'], |
+ 'AdditionalLibraryDirectories': |
+ ['<(DEPTH)/third_party/platformsdk_win7/files/Lib/x64'], |
+ }, |
+ 'VCLibrarianTool': { |
+ 'AdditionalLibraryDirectories!': |
+ ['<(DEPTH)/third_party/platformsdk_win7/files/Lib'], |
+ 'AdditionalLibraryDirectories': |
+ ['<(DEPTH)/third_party/platformsdk_win7/files/Lib/x64'], |
+ }, |
+ }, |
+ 'defines': [ |
+ # Not sure if tcmalloc works on 64-bit Windows. |
+ 'NO_TCMALLOC', |
+ ], |
+ }, |
+ 'Debug_Base': { |
+ 'abstract': 1, |
+ 'xcode_settings': { |
+ 'COPY_PHASE_STRIP': 'NO', |
+ 'GCC_OPTIMIZATION_LEVEL': '<(mac_debug_optimization)', |
+ 'OTHER_CFLAGS': [ '<@(debug_extra_cflags)', ], |
+ }, |
+ 'msvs_settings': { |
+ 'VCCLCompilerTool': { |
+ 'Optimization': '<(win_debug_Optimization)', |
+ 'PreprocessorDefinitions': ['_DEBUG'], |
+ 'BasicRuntimeChecks': '3', |
+ 'RuntimeLibrary': '<(win_debug_RuntimeLibrary)', |
+ }, |
+ 'VCLinkerTool': { |
+ 'LinkIncremental': '<(msvs_debug_link_incremental)', |
+ }, |
+ 'VCResourceCompilerTool': { |
+ 'PreprocessorDefinitions': ['_DEBUG'], |
+ }, |
+ }, |
+ 'conditions': [ |
+ ['OS=="linux"', { |
+ 'cflags': [ |
+ '<@(debug_extra_cflags)', |
+ ], |
+ }], |
+ ], |
+ }, |
+ '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': { |
+ 'Optimization': '<(win_release_Optimization)', |
+ 'RuntimeLibrary': '<(win_release_RuntimeLibrary)', |
+ }, |
+ 'VCLinkerTool': { |
+ 'LinkIncremental': '1', |
+ }, |
+ }, |
+ 'conditions': [ |
+ ['release_valgrind_build==0', { |
+ 'defines': ['NVALGRIND'], |
+ }], |
+ ['win_use_allocator_shim==0', { |
+ 'defines': ['NO_TCMALLOC'], |
+ }], |
+ ['win_release_RuntimeLibrary==2', { |
+ # Visual C++ 2008 barfs when building anything with /MD (msvcrt): |
+ # VC\include\typeinfo(139) : warning C4275: non dll-interface |
+ # class 'stdext::exception' used as base for dll-interface |
+ # class 'std::bad_cast' |
+ 'msvs_disabled_warnings': [4275], |
+ }], |
+ ['OS=="linux"', { |
+ 'cflags': [ |
+ '<@(release_extra_cflags)', |
+ ], |
+ }], |
+ ], |
+ }, |
+ 'Purify_Base': { |
+ 'abstract': 1, |
+ 'defines': [ |
+ 'PURIFY', |
+ 'NO_TCMALLOC', |
+ ], |
+ 'msvs_settings': { |
+ 'VCCLCompilerTool': { |
+ 'Optimization': '0', |
+ 'RuntimeLibrary': '0', |
+ 'BufferSecurityCheck': 'false', |
+ }, |
+ 'VCLinkerTool': { |
+ 'EnableCOMDATFolding': '1', |
+ 'LinkIncremental': '1', |
+ }, |
+ }, |
+ }, |
+ # |
+ # Concrete configurations |
+ # |
+ 'Debug': { |
+ 'inherit_from': ['Common_Base', 'x86_Base', 'Debug_Base'], |
+ }, |
+ 'Release': { |
+ 'inherit_from': ['Common_Base', 'x86_Base', 'Release_Base'], |
+ 'conditions': [ |
+ ['msvs_use_common_release', { |
+ 'includes': ['release.gypi'], |
+ }], |
+ ] |
+ }, |
+ 'conditions': [ |
+ [ 'OS=="win"', { |
+ # TODO(bradnelson): add a gyp mechanism to make this more graceful. |
+ 'Purify': { |
+ 'inherit_from': ['Common_Base', 'x86_Base', 'Release_Base', 'Purify'], |
+ }, |
+ 'Debug_x64': { |
+ 'inherit_from': ['Common_Base', 'x64_Base', 'Debug_Base'], |
+ }, |
+ 'Release_x64': { |
+ 'inherit_from': ['Common_Base', 'x64_Base', 'Release_Base'], |
+ }, |
+ 'Purify_x64': { |
+ 'inherit_from': ['Common_Base', 'x64_Base', 'Release_Base', 'Purify_Base'], |
+ }, |
+ }], |
+ ], |
+ }, |
+ }, |
+ 'conditions': [ |
+ ['OS=="linux" or OS=="freebsd" or OS=="openbsd" or OS=="solaris"', { |
+ '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': { |
+ # Use -fno-strict-aliasing by default since gcc 4.4 has periodic |
+ # issues that slip through the cracks. We could do this just for |
+ # gcc 4.4 but it makes more sense to be consistent on all |
+ # compilers in use. TODO(Craig): turn this off again when |
+ # there is some 4.4 test infrastructure in place and existing |
+ # aliasing issues have been fixed. |
+ 'no_strict_aliasing%': 1, |
+ 'conditions': [['OS=="linux"', {'werror%': '-Werror',}], |
+ ['OS=="freebsd"', {'werror%': '',}], |
+ ['OS=="openbsd"', {'werror%': '',}], |
+ ], |
+ }, |
+ 'cflags': [ |
+ '<(werror)', # See note above about the werror variable. |
+ '-pthread', |
+ '-fno-exceptions', |
+ '-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', |
+ '-D_FILE_OFFSET_BITS=64', |
+ # Don't export any symbols (for example, to plugins we dlopen()). |
+ # Note: this is *required* to make some plugins work. |
+ '-fvisibility=hidden', |
+ ], |
+ 'cflags_cc': [ |
+ '-fno-rtti', |
+ '-fno-threadsafe-statics', |
+ # Make inline functions have hidden visiblity by default. |
+ # Surprisingly, not covered by -fvisibility=hidden. |
+ '-fvisibility-inlines-hidden', |
+ ], |
+ 'ldflags': [ |
+ '-pthread', '-Wl,-z,noexecstack', |
+ ], |
+ 'scons_variable_settings': { |
+ 'LIBPATH': ['$LIB_DIR'], |
+ # Linking of large files uses lots of RAM, so serialize links |
+ # using the handy flock command from util-linux. |
+ 'FLOCK_LINK': ['flock', '$TOP_BUILDDIR/linker.lock', '$LINK'], |
+ 'FLOCK_SHLINK': ['flock', '$TOP_BUILDDIR/linker.lock', '$SHLINK'], |
+ 'FLOCK_LDMODULE': ['flock', '$TOP_BUILDDIR/linker.lock', '$LDMODULE'], |
+ |
+ # We have several cases where archives depend on each other in |
+ # a cyclic fashion. Since the GNU linker does only a single |
+ # pass over the archives we surround the libraries with |
+ # --start-group and --end-group (aka -( and -) ). That causes |
+ # ld to loop over the group until no more undefined symbols |
+ # are found. In an ideal world we would only make groups from |
+ # those libraries which we knew to be in cycles. However, |
+ # that's tough with SCons, so we bodge it by making all the |
+ # archives a group by redefining the linking command here. |
+ # |
+ # TODO: investigate whether we still have cycles that |
+ # require --{start,end}-group. There has been a lot of |
+ # refactoring since this was first coded, which might have |
+ # eliminated the circular dependencies. |
+ # |
+ # Note: $_LIBDIRFLAGS comes before ${LINK,SHLINK,LDMODULE}FLAGS |
+ # so that we prefer our own built libraries (e.g. -lpng) to |
+ # system versions of libraries that pkg-config might turn up. |
+ # TODO(sgk): investigate handling this not by re-ordering the |
+ # flags this way, but by adding a hook to use the SCons |
+ # ParseFlags() option on the output from pkg-config. |
+ 'LINKCOM': [['$FLOCK_LINK', '-o', '$TARGET', |
+ '$_LIBDIRFLAGS', '$LINKFLAGS', '$SOURCES', |
+ '-Wl,--start-group', '$_LIBFLAGS', '-Wl,--end-group']], |
+ 'SHLINKCOM': [['$FLOCK_SHLINK', '-o', '$TARGET', |
+ '$_LIBDIRFLAGS', '$SHLINKFLAGS', '$SOURCES', |
+ '-Wl,--start-group', '$_LIBFLAGS', '-Wl,--end-group']], |
+ 'LDMODULECOM': [['$FLOCK_LDMODULE', '-o', '$TARGET', |
+ '$_LIBDIRFLAGS', '$LDMODULEFLAGS', '$SOURCES', |
+ '-Wl,--start-group', '$_LIBFLAGS', '-Wl,--end-group']], |
+ 'IMPLICIT_COMMAND_DEPENDENCIES': 0, |
+ # -rpath is only used when building with shared libraries. |
+ 'conditions': [ |
+ [ 'library=="shared_library"', { |
+ 'RPATH': '$LIB_DIR', |
+ }], |
+ ], |
+ }, |
+ 'scons_import_variables': [ |
+ 'AS', |
+ 'CC', |
+ 'CXX', |
+ 'LINK', |
+ ], |
+ 'scons_propagate_variables': [ |
+ 'AS', |
+ 'CC', |
+ 'CCACHE_DIR', |
+ 'CXX', |
+ 'DISTCC_DIR', |
+ 'DISTCC_HOSTS', |
+ 'HOME', |
+ 'INCLUDE_SERVER_ARGS', |
+ 'INCLUDE_SERVER_PORT', |
+ 'LINK', |
+ 'CHROME_BUILD_TYPE', |
+ 'CHROMIUM_BUILD', |
+ 'OFFICIAL_BUILD', |
+ ], |
+ 'configurations': { |
+ 'Debug_Base': { |
+ 'variables': { |
+ 'debug_optimize%': '0', |
+ }, |
+ 'defines': [ |
+ '_DEBUG', |
+ ], |
+ 'cflags': [ |
+ '-O>(debug_optimize)', |
+ '-g', |
+ # One can use '-gstabs' to enable building the debugging |
+ # information in STABS format for breakpad's dumpsyms. |
+ ], |
+ 'ldflags': [ |
+ '-rdynamic', # Allows backtrace to resolve symbols. |
+ ], |
+ }, |
+ 'Release_Base': { |
+ 'variables': { |
+ 'release_optimize%': '2', |
+ }, |
+ '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': [ |
+ '-Wl,--gc-sections', |
+ ], |
+ }, |
+ }, |
+ 'variants': { |
+ 'coverage': { |
+ 'cflags': ['-fprofile-arcs', '-ftest-coverage'], |
+ 'ldflags': ['-fprofile-arcs'], |
+ }, |
+ 'profile': { |
+ 'cflags': ['-pg', '-g'], |
+ 'ldflags': ['-pg'], |
+ }, |
+ 'symbols': { |
+ 'cflags': ['-g'], |
+ }, |
+ }, |
+ 'conditions': [ |
+ [ 'target_arch=="ia32"', { |
+ '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. |
+ 'conditions': [ |
+ ['branding=="Chromium" and disable_sse2==0', { |
+ 'cflags': [ |
+ '-march=pentium4', |
+ '-msse2', |
+ '-mfpmath=sse', |
+ ], |
+ }], |
+ # ChromeOS targets Pinetrail, which is sse3, but most of the |
+ # benefit comes from sse2 so this setting allows ChromeOS |
+ # to build on other CPUs. In the future -march=atom would help |
+ # but requires a newer compiler. |
+ ['chromeos==1 and disable_sse2==0', { |
+ 'cflags': [ |
+ '-msse2', |
+ ], |
+ }], |
+ ], |
+ # -mmmx allows mmintrin.h to be used for mmx intrinsics. |
+ # video playback is mmx and sse2 optimized. |
+ 'cflags': [ |
+ '-m32', |
+ '-mmmx', |
+ ], |
+ 'ldflags': [ |
+ '-m32', |
+ ], |
+ }], |
+ ['target_arch=="arm"', { |
+ 'target_conditions': [ |
+ ['_toolset=="target"', { |
+ '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', |
+ ], |
+ 'conditions': [ |
+ ['arm_thumb == 1', { |
+ 'cflags': [ |
+ '-mthumb', |
+ # TODO(piman): -Wa,-mimplicit-it=thumb is needed for |
+ # inline assembly that uses condition codes but it's |
+ # suboptimal. Better would be to #ifdef __thumb__ at the |
+ # right place and have a separate thumb path. |
+ '-Wa,-mimplicit-it=thumb', |
+ ] |
+ }], |
+ ['armv7==1', { |
+ 'cflags': [ |
+ '-march=armv7-a', |
+ '-mtune=cortex-a8', |
+ '-mfloat-abi=softfp', |
+ ], |
+ 'conditions': [ |
+ ['arm_neon==1', { |
+ 'cflags': [ '-mfpu=neon', ], |
+ }, { |
+ 'cflags': [ '-mfpu=<(arm_fpu)', ], |
+ }] |
+ ], |
+ }], |
+ ], |
+ }], |
+ ], |
+ }], |
+ ['linux_fpic==1', { |
+ 'cflags': [ |
+ '-fPIC', |
+ ], |
+ }], |
+ ['sysroot!=""', { |
+ 'target_conditions': [ |
+ ['_toolset=="target"', { |
+ 'cflags': [ |
+ '--sysroot=<(sysroot)', |
+ ], |
+ 'ldflags': [ |
+ '--sysroot=<(sysroot)', |
+ ], |
+ }]] |
+ }], |
+ ['no_strict_aliasing==1', { |
+ 'cflags': [ |
+ '-fno-strict-aliasing', |
+ ], |
+ }], |
+ ['linux_breakpad==1', { |
+ 'cflags': [ '-gstabs' ], |
+ 'defines': ['USE_LINUX_BREAKPAD'], |
+ }], |
+ ['linux_use_seccomp_sandbox==1 and buildtype!="Official"', { |
+ 'defines': ['USE_SECCOMP_SANDBOX'], |
+ }], |
+ ['library=="shared_library"', { |
+ # When building with shared libraries, remove the visiblity-hiding |
+ # flag. |
+ 'cflags!': [ '-fvisibility=hidden' ], |
+ 'conditions': [ |
+ ['target_arch=="x64" or target_arch=="arm"', { |
+ # Shared libraries need -fPIC on x86-64 and arm |
+ 'cflags': ['-fPIC'] |
+ }] |
+ ], |
+ }], |
+ ['linux_use_heapchecker==1', { |
+ 'variables': {'linux_use_tcmalloc%': 1}, |
+ }], |
+ ['linux_use_tcmalloc==0', { |
+ 'defines': ['NO_TCMALLOC'], |
+ }], |
+ ['linux_use_heapchecker==0', { |
+ 'defines': ['NO_HEAPCHECKER'], |
+ }], |
+ ], |
+ }, |
+ }], |
+ # FreeBSD-specific options; note that most FreeBSD options are set above, |
+ # with Linux. |
+ ['OS=="freebsd"', { |
+ 'target_defaults': { |
+ 'ldflags': [ |
+ '-Wl,--no-keep-memory', |
+ ], |
+ }, |
+ }], |
+ ['OS=="solaris"', { |
+ 'cflags!': ['-fvisibility=hidden'], |
+ 'cflags_cc!': ['-fvisibility-inlines-hidden'], |
+ }], |
+ ['OS=="mac"', { |
+ 'target_defaults': { |
+ 'variables': { |
+ # This should be 'mac_real_dsym%', but there seems to be a bug |
+ # with % in variables that are intended to be set to different |
+ # values in different targets, like this one. |
+ 'mac_real_dsym': 0, # Fake .dSYMs are fine in most cases. |
+ }, |
+ 'mac_bundle': 0, |
+ 'xcode_settings': { |
+ 'ALWAYS_SEARCH_USER_PATHS': 'NO', |
+ 'GCC_C_LANGUAGE_STANDARD': 'c99', # -std=c99 |
+ 'GCC_CW_ASM_SYNTAX': 'NO', # No -fasm-blocks |
+ 'GCC_DYNAMIC_NO_PIC': 'NO', # No -mdynamic-no-pic |
+ # (Equivalent to -fPIC) |
+ 'GCC_ENABLE_CPP_EXCEPTIONS': 'NO', # -fno-exceptions |
+ 'GCC_ENABLE_CPP_RTTI': 'NO', # -fno-rtti |
+ 'GCC_ENABLE_PASCAL_STRINGS': 'NO', # No -mpascal-strings |
+ # GCC_INLINES_ARE_PRIVATE_EXTERN maps to -fvisibility-inlines-hidden |
+ 'GCC_INLINES_ARE_PRIVATE_EXTERN': 'YES', |
+ 'GCC_OBJC_CALL_CXX_CDTORS': 'YES', # -fobjc-call-cxx-cdtors |
+ 'GCC_SYMBOLS_PRIVATE_EXTERN': 'YES', # -fvisibility=hidden |
+ 'GCC_THREADSAFE_STATICS': 'NO', # -fno-threadsafe-statics |
+ 'GCC_TREAT_WARNINGS_AS_ERRORS': 'YES', # -Werror |
+ 'GCC_VERSION': '4.2', |
+ 'GCC_WARN_ABOUT_MISSING_NEWLINE': 'YES', # -Wnewline-eof |
+ # MACOSX_DEPLOYMENT_TARGET maps to -mmacosx-version-min |
+ 'MACOSX_DEPLOYMENT_TARGET': '<(mac_deployment_target)', |
+ 'PREBINDING': 'NO', # No -Wl,-prebind |
+ 'USE_HEADERMAP': 'NO', |
+ 'WARNING_CFLAGS': ['-Wall', '-Wendif-labels'], |
+ 'conditions': [ |
+ ['chromium_mac_pch', {'GCC_PRECOMPILE_PREFIX_HEADER': 'YES'}, |
+ {'GCC_PRECOMPILE_PREFIX_HEADER': 'NO'} |
+ ], |
+ ], |
+ }, |
+ 'target_conditions': [ |
+ ['_type!="static_library"', { |
+ 'xcode_settings': {'OTHER_LDFLAGS': ['-Wl,-search_paths_first']}, |
+ }], |
+ ['_mac_bundle', { |
+ 'xcode_settings': {'OTHER_LDFLAGS': ['-Wl,-ObjC']}, |
+ }], |
+ ['_type=="executable" or _type=="shared_library"', { |
+ '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', |
+ 'target_conditions': [ |
+ ['_type=="shared_library"', { |
+ # 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" |
+ ], # target_conditions |
+ }, # 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" |
+ ], # target_conditions |
+ }, # target_defaults |
+ }], # OS=="mac" |
+ ['OS=="win"', { |
+ 'target_defaults': { |
+ 'defines': [ |
+ '_WIN32_WINNT=0x0600', |
+ 'WINVER=0x0600', |
+ 'WIN32', |
+ '_WINDOWS', |
+ '_HAS_EXCEPTIONS=0', |
+ 'NOMINMAX', |
+ '_CRT_RAND_S', |
+ 'CERT_CHAIN_PARA_HAS_EXTRA_FIELDS', |
+ 'WIN32_LEAN_AND_MEAN', |
+ '_SECURE_ATL', |
+ '_HAS_TR1=0', |
+ ], |
+ 'msvs_system_include_dirs': [ |
+ '<(DEPTH)/third_party/platformsdk_win7/files/Include', |
+ '$(VSInstallDir)/VC/atlmfc/include', |
+ ], |
+ 'msvs_cygwin_dirs': ['<(DEPTH)/third_party/cygwin'], |
+ 'msvs_disabled_warnings': [4396, 4503, 4819], |
+ 'msvs_settings': { |
+ 'VCCLCompilerTool': { |
+ 'MinimalRebuild': 'false', |
+ 'ExceptionHandling': '0', |
+ 'BufferSecurityCheck': 'true', |
+ 'EnableFunctionLevelLinking': 'true', |
+ 'RuntimeTypeInfo': 'false', |
+ 'WarningLevel': '3', |
+ 'WarnAsError': 'true', |
+ 'DebugInformationFormat': '3', |
+ 'conditions': [ |
+ [ 'msvs_multi_core_compile', { |
+ 'AdditionalOptions': ['/MP'], |
+ }], |
+ ], |
+ }, |
+ 'VCLibrarianTool': { |
+ 'AdditionalOptions': ['/ignore:4221'], |
+ 'AdditionalLibraryDirectories': |
+ ['<(DEPTH)/third_party/platformsdk_win7/files/Lib'], |
+ }, |
+ 'VCLinkerTool': { |
+ 'AdditionalDependencies': [ |
+ 'wininet.lib', |
+ 'version.lib', |
+ 'msimg32.lib', |
+ 'ws2_32.lib', |
+ 'usp10.lib', |
+ 'psapi.lib', |
+ 'dbghelp.lib', |
+ ], |
+ 'AdditionalLibraryDirectories': |
+ ['<(DEPTH)/third_party/platformsdk_win7/files/Lib'], |
+ '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': 'dlldata.c', |
+ 'InterfaceIdentifierFileName': '$(InputName)_i.c', |
+ 'ProxyFileName': '$(InputName)_p.c', |
+ }, |
+ 'VCResourceCompilerTool': { |
+ 'Culture' : '1033', |
+ 'AdditionalIncludeDirectories': ['<(DEPTH)'], |
+ }, |
+ }, |
+ }, |
+ }], |
+ ['disable_nacl==1 or OS=="freebsd" or OS=="openbsd" or OS=="solaris"', { |
+ 'target_defaults': { |
+ 'defines': [ |
+ 'DISABLE_NACL', |
+ ], |
+ }, |
+ }], |
+ ['OS=="win" and msvs_use_common_linker_extras', { |
+ 'target_defaults': { |
+ 'msvs_settings': { |
+ 'VCLinkerTool': { |
+ 'DelayLoadDLLs': [ |
+ 'dbghelp.dll', |
+ 'dwmapi.dll', |
+ 'uxtheme.dll', |
+ ], |
+ }, |
+ }, |
+ 'configurations': { |
+ 'x86_Base': { |
+ 'msvs_settings': { |
+ 'VCLinkerTool': { |
+ 'AdditionalOptions': [ |
+ '/safeseh', |
+ '/dynamicbase', |
+ '/ignore:4199', |
+ '/ignore:4221', |
+ '/nxcompat', |
+ ], |
+ }, |
+ }, |
+ }, |
+ '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', |
+ ], |
+ }, |
+ }], |
+ ], |
+ 'scons_settings': { |
+ 'sconsbuild_dir': '<(DEPTH)/sconsbuild', |
+ 'tools': ['ar', 'as', 'gcc', 'g++', 'gnulink', 'chromium_builders'], |
+ }, |
+ 'xcode_settings': { |
+ # DON'T ADD ANYTHING NEW TO THIS BLOCK UNLESS YOU REALLY REALLY NEED IT! |
+ # This block adds *project-wide* configuration settings to each project |
+ # file. It's almost always wrong to put things here. Specify your |
+ # custom xcode_settings in target_defaults to add them to targets instead. |
+ |
+ # In an Xcode Project Info window, the "Base SDK for All Configurations" |
+ # setting sets the SDK on a project-wide basis. In order to get the |
+ # configured SDK to show properly in the Xcode UI, SDKROOT must be set |
+ # here at the project level. |
+ 'SDKROOT': 'macosx<(mac_sdk)', # -isysroot |
+ |
+ # The Xcode generator will look for an xcode_settings section at the root |
+ # of each dict and use it to apply settings on a file-wide basis. Most |
+ # settings should not be here, they should be in target-specific |
+ # xcode_settings sections, or better yet, should use non-Xcode-specific |
+ # settings in target dicts. SYMROOT is a special case, because many other |
+ # Xcode variables depend on it, including variables such as |
+ # PROJECT_DERIVED_FILE_DIR. When a source group corresponding to something |
+ # like PROJECT_DERIVED_FILE_DIR is added to a project, in order for the |
+ # files to appear (when present) in the UI as actual files and not red |
+ # red "missing file" proxies, the correct path to PROJECT_DERIVED_FILE_DIR, |
+ # and therefore SYMROOT, needs to be set at the project level. |
+ 'SYMROOT': '<(DEPTH)/xcodebuild', |
+ }, |
+} |
+ |
+# Local Variables: |
+# tab-width:2 |
+# indent-tabs-mode:nil |
+# End: |
+# vim: set expandtab tabstop=2 shiftwidth=2: |
Property changes on: src\client\windows\build\common.gypi |
___________________________________________________________________ |
Added: svn:executable |
+ * |