1# 2# libjingle 3# Copyright 2013 Google Inc. 4# 5# Redistribution and use in source and binary forms, with or without 6# modification, are permitted provided that the following conditions are met: 7# 8# 1. Redistributions of source code must retain the above copyright notice, 9# this list of conditions and the following disclaimer. 10# 2. Redistributions in binary form must reproduce the above copyright notice, 11# this list of conditions and the following disclaimer in the documentation 12# and/or other materials provided with the distribution. 13# 3. The name of the author may not be used to endorse or promote products 14# derived from this software without specific prior written permission. 15# 16# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 17# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 18# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO 19# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 20# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 21# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 22# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 23# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 24# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 25# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26 27# Copied from Chromium's src/build/isolate.gypi 28# 29# It was necessary to copy this file because the path to build/common.gypi is 30# different for the standalone and Chromium builds. Gyp doesn't permit 31# conditional inclusion or variable expansion in include paths. 32# http://code.google.com/p/gyp/wiki/InputFormatReference#Including_Other_Files 33# 34# Local modifications: 35# * Removed include of '../chrome/version.gypi'. 36# * Removed passing of version_full variable created in version.gypi: 37# '--extra-variable', 'version_full=<(version_full)', 38 39# This file is meant to be included into a target to provide a rule 40# to "build" .isolate files into a .isolated file. 41# 42# To use this, create a gyp target with the following form: 43# 'conditions': [ 44# ['test_isolation_mode != "noop"', { 45# 'targets': [ 46# { 47# 'target_name': 'foo_test_run', 48# 'type': 'none', 49# 'dependencies': [ 50# 'foo_test', 51# ], 52# 'includes': [ 53# '../build/isolate.gypi', 54# 'foo_test.isolate', 55# ], 56# 'sources': [ 57# 'foo_test.isolate', 58# ], 59# }, 60# ], 61# }], 62# ], 63# 64# Note: foo_test.isolate is included and a source file. It is an inherent 65# property of the .isolate format. This permits to define GYP variables but is 66# a stricter format than GYP so isolate.py can read it. 67# 68# The generated .isolated file will be: 69# <(PRODUCT_DIR)/foo_test.isolated 70# 71# See http://dev.chromium.org/developers/testing/isolated-testing/for-swes 72# for more information. 73 74{ 75 'rules': [ 76 { 77 'rule_name': 'isolate', 78 'extension': 'isolate', 79 'inputs': [ 80 # Files that are known to be involved in this step. 81 '<(DEPTH)/tools/isolate_driver.py', 82 '<(DEPTH)/tools/swarming_client/isolate.py', 83 '<(DEPTH)/tools/swarming_client/run_isolated.py', 84 ], 85 'outputs': [], 86 'action': [ 87 'python', 88 '<(DEPTH)/tools/isolate_driver.py', 89 '<(test_isolation_mode)', 90 '--isolated', '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).isolated', 91 '--isolate', '<(RULE_INPUT_PATH)', 92 93 # Variables should use the -V FOO=<(FOO) form so frequent values, 94 # like '0' or '1', aren't stripped out by GYP. Run 'isolate.py help' for 95 # more details. 96 97 # Path variables are used to replace file paths when loading a .isolate 98 # file 99 '--path-variable', 'DEPTH', '<(DEPTH)', 100 '--path-variable', 'PRODUCT_DIR', '<(PRODUCT_DIR) ', 101 102 # Note: This list must match DefaultConfigVariables() 103 # in build/android/pylib/utils/isolator.py 104 '--config-variable', 'CONFIGURATION_NAME=<(CONFIGURATION_NAME)', 105 '--config-variable', 'OS=<(OS)', 106 '--config-variable', 'asan=<(asan)', 107 '--config-variable', 'branding=<(branding)', 108 '--config-variable', 'chromeos=<(chromeos)', 109 '--config-variable', 'component=<(component)', 110 '--config-variable', 'disable_nacl=<(disable_nacl)', 111 '--config-variable', 'enable_pepper_cdms=<(enable_pepper_cdms)', 112 '--config-variable', 'enable_plugins=<(enable_plugins)', 113 '--config-variable', 'fastbuild=<(fastbuild)', 114 '--config-variable', 'icu_use_data_file_flag=<(icu_use_data_file_flag)', 115 # TODO(kbr): move this to chrome_tests.gypi:gles2_conform_tests_run 116 # once support for user-defined config variables is added. 117 '--config-variable', 118 'internal_gles2_conform_tests=<(internal_gles2_conform_tests)', 119 '--config-variable', 'kasko=<(kasko)', 120 '--config-variable', 'lsan=<(lsan)', 121 '--config-variable', 'msan=<(msan)', 122 '--config-variable', 'target_arch=<(target_arch)', 123 '--config-variable', 'tsan=<(tsan)', 124 '--config-variable', 'use_custom_libcxx=<(use_custom_libcxx)', 125 '--config-variable', 'use_instrumented_libraries=<(use_instrumented_libraries)', 126 '--config-variable', 127 'use_prebuilt_instrumented_libraries=<(use_prebuilt_instrumented_libraries)', 128 '--config-variable', 'use_openssl=<(use_openssl)', 129 '--config-variable', 'use_ozone=<(use_ozone)', 130 '--config-variable', 'use_x11=<(use_x11)', 131 '--config-variable', 'v8_use_external_startup_data=<(v8_use_external_startup_data)', 132 ], 133 'conditions': [ 134 # Note: When gyp merges lists, it appends them to the old value. 135 ['OS=="mac"', { 136 'action': [ 137 '--extra-variable', 'mac_product_name=<(mac_product_name)', 138 ], 139 }], 140 ["test_isolation_mode == 'prepare'", { 141 'outputs': [ 142 '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).isolated.gen.json', 143 ], 144 }, { 145 'outputs': [ 146 '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).isolated', 147 ], 148 }], 149 ['OS=="win"', { 150 'action': [ 151 '--config-variable', 'msvs_version=<(MSVS_VERSION)', 152 ], 153 }, { 154 'action': [ 155 '--config-variable', 'msvs_version=0', 156 ], 157 }], 158 ], 159 }, 160 ], 161} 162