2018-05-14 16:50:38 +00:00
|
|
|
# Copyright 2018 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.
|
|
|
|
|
|
|
|
|
|
|
|
from . import util
|
|
|
|
|
|
|
|
|
2018-08-03 14:07:47 +00:00
|
|
|
# See mapping of Xcode version to Xcode build version here:
|
|
|
|
# https://chromium.googlesource.com/chromium/tools/build/+/master/scripts/slave/recipe_modules/ios/api.py#37
|
|
|
|
# When updating XCODE_BUILD_VERSION, you will also need to update
|
|
|
|
# XCODE_CLANG_VERSION.
|
|
|
|
XCODE_BUILD_VERSION = '9c40b'
|
|
|
|
XCODE_CLANG_VERSION = '9.0.0'
|
|
|
|
|
|
|
|
|
2018-05-18 11:36:55 +00:00
|
|
|
def build_command_buffer(api, chrome_dir, skia_dir, out):
|
2018-05-14 16:50:38 +00:00
|
|
|
api.run(api.python, 'build command_buffer',
|
2018-05-18 11:36:55 +00:00
|
|
|
script=skia_dir.join('tools', 'build_command_buffer.py'),
|
2018-05-14 16:50:38 +00:00
|
|
|
args=[
|
2018-05-18 11:36:55 +00:00
|
|
|
'--chrome-dir', chrome_dir,
|
|
|
|
'--output-dir', out,
|
2018-05-14 16:50:38 +00:00
|
|
|
'--no-sync', '--no-hooks', '--make-output-dir'])
|
|
|
|
|
|
|
|
|
|
|
|
def compile_swiftshader(api, swiftshader_root, cc, cxx, out):
|
|
|
|
"""Build SwiftShader with CMake.
|
|
|
|
|
|
|
|
Building SwiftShader works differently from any other Skia third_party lib.
|
|
|
|
See discussion in skia:7671 for more detail.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
swiftshader_root: root of the SwiftShader checkout.
|
|
|
|
cc, cxx: compiler binaries to use
|
|
|
|
out: target directory for libEGL.so and libGLESv2.so
|
|
|
|
"""
|
|
|
|
cmake_bin = str(api.vars.slave_dir.join('cmake_linux', 'bin'))
|
|
|
|
env = {
|
|
|
|
'CC': cc,
|
|
|
|
'CXX': cxx,
|
|
|
|
'PATH': '%%(PATH)s:%s' % cmake_bin
|
|
|
|
}
|
|
|
|
api.file.ensure_directory('makedirs swiftshader_out', out)
|
|
|
|
with api.context(cwd=out, env=env):
|
|
|
|
api.run(api.step, 'swiftshader cmake',
|
2018-06-11 16:19:40 +00:00
|
|
|
cmd=['cmake', '-DBUILD_TESTS=OFF', swiftshader_root, '-GNinja'])
|
2018-05-14 16:50:38 +00:00
|
|
|
api.run(api.step, 'swiftshader ninja',
|
|
|
|
cmd=['ninja', '-C', out, 'libEGL.so', 'libGLESv2.so'])
|
|
|
|
|
|
|
|
|
2018-05-18 11:36:55 +00:00
|
|
|
def compile_fn(api, checkout_root, out_dir):
|
|
|
|
skia_dir = checkout_root.join('skia')
|
2018-05-14 16:50:38 +00:00
|
|
|
compiler = api.vars.builder_cfg.get('compiler', '')
|
|
|
|
configuration = api.vars.builder_cfg.get('configuration', '')
|
|
|
|
extra_tokens = api.vars.extra_tokens
|
|
|
|
os = api.vars.builder_cfg.get('os', '')
|
|
|
|
target_arch = api.vars.builder_cfg.get('target_arch', '')
|
|
|
|
|
Update win_toolchain, and refactor how it's built
The old win_toolchain script required a Chromium checkout, and
extracted portions of the win_toolchain from that to build the
Skia asset. Instead, use the depot_tools script that assembles
a toolchain from a locally installed MSVC.
The create script doesn't do that, but relies on the user to
run that script first. Automating everything would be a nice
follow-up.
With the new strategy, the toolchain directory is simpler, and
no longer contains the depot_tools kruft or extra directories.
Adjust the bot scripts accordingly. (Renaming the directory to
win_toolchain from 't' would be a nice touch, too).
Finally, I built the new toolchain with the updated process,
and included the ARM64 compiler and libraries, so we can set
up a bot to build Windows ARM64.
Docs-Preview: https://skia.org/?cl=176968
Bug: skia:8569
Change-Id: I4bdf3cfb29d50f4464853445d0226241e70c33b4
Reviewed-on: https://skia-review.googlesource.com/c/176968
Reviewed-by: Mike Klein <mtklein@google.com>
Reviewed-by: Eric Boren <borenet@google.com>
Commit-Queue: Brian Osman <brianosman@google.com>
2018-12-12 14:58:26 +00:00
|
|
|
clang_linux = str(api.vars.slave_dir.join('clang_linux'))
|
2018-12-12 18:28:09 +00:00
|
|
|
win_toolchain = str(api.vars.slave_dir.join('win_toolchain'))
|
Update win_toolchain, and refactor how it's built
The old win_toolchain script required a Chromium checkout, and
extracted portions of the win_toolchain from that to build the
Skia asset. Instead, use the depot_tools script that assembles
a toolchain from a locally installed MSVC.
The create script doesn't do that, but relies on the user to
run that script first. Automating everything would be a nice
follow-up.
With the new strategy, the toolchain directory is simpler, and
no longer contains the depot_tools kruft or extra directories.
Adjust the bot scripts accordingly. (Renaming the directory to
win_toolchain from 't' would be a nice touch, too).
Finally, I built the new toolchain with the updated process,
and included the ARM64 compiler and libraries, so we can set
up a bot to build Windows ARM64.
Docs-Preview: https://skia.org/?cl=176968
Bug: skia:8569
Change-Id: I4bdf3cfb29d50f4464853445d0226241e70c33b4
Reviewed-on: https://skia-review.googlesource.com/c/176968
Reviewed-by: Mike Klein <mtklein@google.com>
Reviewed-by: Eric Boren <borenet@google.com>
Commit-Queue: Brian Osman <brianosman@google.com>
2018-12-12 14:58:26 +00:00
|
|
|
moltenvk = str(api.vars.slave_dir.join('moltenvk'))
|
2018-05-14 16:50:38 +00:00
|
|
|
|
|
|
|
cc, cxx = None, None
|
|
|
|
extra_cflags = []
|
|
|
|
extra_ldflags = []
|
|
|
|
args = {}
|
|
|
|
env = {}
|
|
|
|
|
2018-08-01 20:11:37 +00:00
|
|
|
if os == 'Mac':
|
2018-08-03 14:07:47 +00:00
|
|
|
extra_cflags.append(
|
|
|
|
'-DDUMMY_xcode_build_version=%s' % XCODE_BUILD_VERSION)
|
|
|
|
mac_toolchain_cmd = api.vars.slave_dir.join(
|
|
|
|
'mac_toolchain', 'mac_toolchain')
|
|
|
|
xcode_app_path = api.vars.cache_dir.join('Xcode.app')
|
|
|
|
# Copied from
|
|
|
|
# https://chromium.googlesource.com/chromium/tools/build/+/e19b7d9390e2bb438b566515b141ed2b9ed2c7c2/scripts/slave/recipe_modules/ios/api.py#322
|
|
|
|
with api.step.nest('ensure xcode') as step_result:
|
|
|
|
step_result.presentation.step_text = (
|
|
|
|
'Ensuring Xcode version %s in %s' % (
|
|
|
|
XCODE_BUILD_VERSION, xcode_app_path))
|
|
|
|
install_xcode_cmd = [
|
|
|
|
mac_toolchain_cmd, 'install',
|
|
|
|
# "ios" is needed for simulator builds
|
|
|
|
# (Build-Mac-Clang-x64-Release-iOS).
|
|
|
|
'-kind', 'ios',
|
|
|
|
'-xcode-version', XCODE_BUILD_VERSION,
|
|
|
|
'-output-dir', xcode_app_path,
|
|
|
|
]
|
|
|
|
api.step('install xcode', install_xcode_cmd)
|
|
|
|
api.step('select xcode', [
|
|
|
|
'sudo', 'xcode-select', '-switch', xcode_app_path])
|
2018-08-01 20:11:37 +00:00
|
|
|
|
2018-05-14 16:50:38 +00:00
|
|
|
if compiler == 'Clang' and api.vars.is_linux:
|
|
|
|
cc = clang_linux + '/bin/clang'
|
|
|
|
cxx = clang_linux + '/bin/clang++'
|
|
|
|
extra_cflags .append('-B%s/bin' % clang_linux)
|
|
|
|
extra_ldflags.append('-B%s/bin' % clang_linux)
|
|
|
|
extra_ldflags.append('-fuse-ld=lld')
|
|
|
|
extra_cflags.append('-DDUMMY_clang_linux_version=%s' %
|
2018-05-18 11:36:55 +00:00
|
|
|
api.run.asset_version('clang_linux', skia_dir))
|
2018-06-08 16:37:53 +00:00
|
|
|
if 'Static' in extra_tokens:
|
2018-05-14 16:50:38 +00:00
|
|
|
extra_ldflags.extend(['-static-libstdc++', '-static-libgcc'])
|
|
|
|
|
|
|
|
elif compiler == 'Clang':
|
|
|
|
cc, cxx = 'clang', 'clang++'
|
|
|
|
elif compiler == 'GCC':
|
|
|
|
if target_arch in ['mips64el', 'loongson3a']:
|
|
|
|
mips64el_toolchain_linux = str(api.vars.slave_dir.join(
|
|
|
|
'mips64el_toolchain_linux'))
|
|
|
|
cc = mips64el_toolchain_linux + '/bin/mips64el-linux-gnuabi64-gcc-7'
|
|
|
|
cxx = mips64el_toolchain_linux + '/bin/mips64el-linux-gnuabi64-g++-7'
|
|
|
|
env['LD_LIBRARY_PATH'] = (
|
|
|
|
mips64el_toolchain_linux + '/lib/x86_64-linux-gnu/')
|
|
|
|
extra_ldflags.append('-L' + mips64el_toolchain_linux +
|
|
|
|
'/mips64el-linux-gnuabi64/lib')
|
|
|
|
extra_cflags.extend([
|
|
|
|
'-Wno-format-truncation',
|
|
|
|
'-Wno-uninitialized',
|
|
|
|
('-DDUMMY_mips64el_toolchain_linux_version=%s' %
|
2018-05-18 11:36:55 +00:00
|
|
|
api.run.asset_version('mips64el_toolchain_linux', skia_dir))
|
2018-05-14 16:50:38 +00:00
|
|
|
])
|
|
|
|
if configuration == 'Release':
|
|
|
|
# This warning is only triggered when fuzz_canvas is inlined.
|
|
|
|
extra_cflags.append('-Wno-strict-overflow')
|
|
|
|
args.update({
|
|
|
|
'skia_use_system_freetype2': 'false',
|
|
|
|
'skia_use_fontconfig': 'false',
|
|
|
|
'skia_enable_gpu': 'false',
|
|
|
|
})
|
|
|
|
else:
|
|
|
|
cc, cxx = 'gcc', 'g++'
|
2018-08-03 14:26:00 +00:00
|
|
|
|
2018-12-12 16:30:19 +00:00
|
|
|
if 'Tidy' in extra_tokens:
|
|
|
|
# Swap in clang-tidy.sh for clang++, but update PATH so it can find clang++.
|
|
|
|
cxx = skia_dir.join("tools/clang-tidy.sh")
|
|
|
|
env['PATH'] = '%s:%%(PATH)s' % (clang_linux + '/bin')
|
|
|
|
|
2018-05-14 16:50:38 +00:00
|
|
|
if 'Coverage' in extra_tokens:
|
|
|
|
# See https://clang.llvm.org/docs/SourceBasedCodeCoverage.html for
|
|
|
|
# more info on using llvm to gather coverage information.
|
|
|
|
extra_cflags.append('-fprofile-instr-generate')
|
|
|
|
extra_cflags.append('-fcoverage-mapping')
|
|
|
|
extra_ldflags.append('-fprofile-instr-generate')
|
|
|
|
extra_ldflags.append('-fcoverage-mapping')
|
|
|
|
|
|
|
|
if compiler != 'MSVC' and configuration == 'Debug':
|
|
|
|
extra_cflags.append('-O1')
|
|
|
|
|
|
|
|
if 'Exceptions' in extra_tokens:
|
|
|
|
extra_cflags.append('/EHsc')
|
|
|
|
if 'Fast' in extra_tokens:
|
|
|
|
extra_cflags.extend(['-march=native', '-fomit-frame-pointer', '-O3',
|
|
|
|
'-ffp-contract=off'])
|
|
|
|
|
|
|
|
if len(extra_tokens) == 1 and extra_tokens[0].startswith('SK'):
|
|
|
|
extra_cflags.append('-D' + extra_tokens[0])
|
|
|
|
# If we're limiting Skia at all, drop skcms to portable code.
|
|
|
|
if 'SK_CPU_LIMIT' in extra_tokens[0]:
|
|
|
|
extra_cflags.append('-DSKCMS_PORTABLE')
|
|
|
|
|
|
|
|
|
|
|
|
if 'MSAN' in extra_tokens:
|
|
|
|
extra_ldflags.append('-L' + clang_linux + '/msan')
|
|
|
|
|
|
|
|
if configuration != 'Debug':
|
|
|
|
args['is_debug'] = 'false'
|
|
|
|
if 'ANGLE' in extra_tokens:
|
|
|
|
args['skia_use_angle'] = 'true'
|
|
|
|
if 'SwiftShader' in extra_tokens:
|
2018-05-18 11:36:55 +00:00
|
|
|
swiftshader_root = skia_dir.join('third_party', 'externals', 'swiftshader')
|
2018-05-16 13:34:07 +00:00
|
|
|
swiftshader_out = out_dir.join('swiftshader_out')
|
2018-05-14 16:50:38 +00:00
|
|
|
compile_swiftshader(api, swiftshader_root, cc, cxx, swiftshader_out)
|
|
|
|
args['skia_use_egl'] = 'true'
|
|
|
|
extra_cflags.extend([
|
|
|
|
'-DGR_EGL_TRY_GLES3_THEN_GLES2',
|
2018-05-24 18:50:29 +00:00
|
|
|
'-I%s' % skia_dir.join(
|
|
|
|
'third_party', 'externals', 'egl-registry', 'api'),
|
|
|
|
'-I%s' % skia_dir.join(
|
|
|
|
'third_party', 'externals', 'opengl-registry', 'api'),
|
2018-05-14 16:50:38 +00:00
|
|
|
])
|
|
|
|
extra_ldflags.extend([
|
|
|
|
'-L%s' % swiftshader_out,
|
|
|
|
])
|
|
|
|
if 'CommandBuffer' in extra_tokens:
|
2018-05-18 11:36:55 +00:00
|
|
|
chrome_dir = checkout_root
|
|
|
|
api.run.run_once(build_command_buffer, api, chrome_dir, skia_dir, out_dir)
|
2018-05-14 16:50:38 +00:00
|
|
|
if 'MSAN' in extra_tokens:
|
|
|
|
args['skia_use_fontconfig'] = 'false'
|
|
|
|
if 'ASAN' in extra_tokens or 'UBSAN' in extra_tokens:
|
|
|
|
args['skia_enable_spirv_validation'] = 'false'
|
|
|
|
if 'NoDEPS' in extra_tokens:
|
|
|
|
args.update({
|
|
|
|
'is_official_build': 'true',
|
|
|
|
'skia_enable_fontmgr_empty': 'true',
|
|
|
|
'skia_enable_gpu': 'true',
|
|
|
|
|
|
|
|
'skia_enable_pdf': 'false',
|
|
|
|
'skia_use_expat': 'false',
|
|
|
|
'skia_use_freetype': 'false',
|
2019-02-22 20:55:39 +00:00
|
|
|
'skia_use_harfbuzz': 'false',
|
2018-05-14 16:50:38 +00:00
|
|
|
'skia_use_libjpeg_turbo': 'false',
|
|
|
|
'skia_use_libpng': 'false',
|
|
|
|
'skia_use_libwebp': 'false',
|
|
|
|
'skia_use_vulkan': 'false',
|
|
|
|
'skia_use_zlib': 'false',
|
|
|
|
})
|
|
|
|
if 'NoGPU' in extra_tokens:
|
|
|
|
args['skia_enable_gpu'] = 'false'
|
|
|
|
if 'Shared' in extra_tokens:
|
|
|
|
args['is_component_build'] = 'true'
|
|
|
|
if 'Vulkan' in extra_tokens and not 'Android' in extra_tokens:
|
2019-01-04 14:50:52 +00:00
|
|
|
args['skia_use_vulkan'] = 'true'
|
2018-05-14 16:50:38 +00:00
|
|
|
args['skia_enable_vulkan_debug_layers'] = 'false'
|
2018-05-17 16:17:10 +00:00
|
|
|
if 'MoltenVK' in extra_tokens:
|
|
|
|
args['skia_moltenvk_path'] = '"%s"' % moltenvk
|
2018-05-14 16:50:38 +00:00
|
|
|
if 'Metal' in extra_tokens:
|
|
|
|
args['skia_use_metal'] = 'true'
|
2018-06-29 00:41:04 +00:00
|
|
|
if 'OpenCL' in extra_tokens:
|
|
|
|
args['skia_use_opencl'] = 'true'
|
|
|
|
if api.vars.is_linux:
|
2018-08-07 20:58:15 +00:00
|
|
|
extra_cflags.append(
|
|
|
|
'-isystem%s' % api.vars.slave_dir.join('opencl_headers'))
|
2018-06-29 00:41:04 +00:00
|
|
|
extra_ldflags.append(
|
|
|
|
'-L%s' % api.vars.slave_dir.join('opencl_ocl_icd_linux'))
|
2018-08-07 20:58:15 +00:00
|
|
|
elif 'Win' in os:
|
|
|
|
extra_cflags.append(
|
|
|
|
'-imsvc%s' % api.vars.slave_dir.join('opencl_headers'))
|
|
|
|
extra_ldflags.append(
|
|
|
|
'/LIBPATH:%s' %
|
|
|
|
skia_dir.join('third_party', 'externals', 'opencl-lib', '3-0', 'lib',
|
|
|
|
'x86_64'))
|
2018-05-14 16:50:38 +00:00
|
|
|
if 'iOS' in extra_tokens:
|
|
|
|
# Bots use Chromium signing cert.
|
|
|
|
args['skia_ios_identity'] = '".*GS9WA.*"'
|
|
|
|
args['skia_ios_profile'] = '"Upstream Testing Provisioning Profile"'
|
|
|
|
if 'CheckGeneratedFiles' in extra_tokens:
|
|
|
|
args['skia_compile_processors'] = 'true'
|
|
|
|
args['skia_generate_workarounds'] = 'true'
|
|
|
|
if compiler == 'Clang' and 'Win' in os:
|
|
|
|
args['clang_win'] = '"%s"' % api.vars.slave_dir.join('clang_win')
|
|
|
|
extra_cflags.append('-DDUMMY_clang_win_version=%s' %
|
2018-05-18 11:36:55 +00:00
|
|
|
api.run.asset_version('clang_win', skia_dir))
|
2018-05-14 16:50:38 +00:00
|
|
|
|
|
|
|
sanitize = ''
|
|
|
|
for t in extra_tokens:
|
|
|
|
if t.endswith('SAN'):
|
|
|
|
sanitize = t
|
2019-02-06 15:46:14 +00:00
|
|
|
if api.vars.is_linux and t == 'ASAN':
|
|
|
|
# skia:8712 and skia:8713
|
|
|
|
extra_cflags.append('-DSK_ENABLE_SCOPED_LSAN_SUPPRESSIONS')
|
2018-05-14 16:50:38 +00:00
|
|
|
if 'SafeStack' in extra_tokens:
|
|
|
|
assert sanitize == ''
|
|
|
|
sanitize = 'safe-stack'
|
2019-02-05 15:33:05 +00:00
|
|
|
if 'MSRTC' in extra_tokens:
|
|
|
|
assert sanitize == ''
|
|
|
|
sanitize = 'MSVC'
|
2018-05-14 16:50:38 +00:00
|
|
|
|
2019-02-11 19:18:04 +00:00
|
|
|
if 'Wuffs' in extra_tokens:
|
|
|
|
args['skia_use_wuffs'] = 'true'
|
|
|
|
|
2018-05-14 16:50:38 +00:00
|
|
|
for (k,v) in {
|
|
|
|
'cc': cc,
|
|
|
|
'cxx': cxx,
|
|
|
|
'sanitize': sanitize,
|
|
|
|
'target_cpu': target_arch,
|
|
|
|
'target_os': 'ios' if 'iOS' in extra_tokens else '',
|
|
|
|
'win_sdk': win_toolchain + '/win_sdk' if 'Win' in os else '',
|
|
|
|
'win_vc': win_toolchain + '/VC' if 'Win' in os else '',
|
|
|
|
}.iteritems():
|
|
|
|
if v:
|
|
|
|
args[k] = '"%s"' % v
|
|
|
|
if extra_cflags:
|
|
|
|
args['extra_cflags'] = repr(extra_cflags).replace("'", '"')
|
|
|
|
if extra_ldflags:
|
|
|
|
args['extra_ldflags'] = repr(extra_ldflags).replace("'", '"')
|
|
|
|
|
|
|
|
gn_args = ' '.join('%s=%s' % (k,v) for (k,v) in sorted(args.iteritems()))
|
2018-06-19 14:34:32 +00:00
|
|
|
gn = skia_dir.join('bin', 'gn')
|
2018-05-14 16:50:38 +00:00
|
|
|
|
2018-05-18 11:36:55 +00:00
|
|
|
with api.context(cwd=skia_dir):
|
2018-05-14 16:50:38 +00:00
|
|
|
api.run(api.python,
|
|
|
|
'fetch-gn',
|
2018-05-18 11:36:55 +00:00
|
|
|
script=skia_dir.join('bin', 'fetch-gn'),
|
2018-05-14 16:50:38 +00:00
|
|
|
infra_step=True)
|
|
|
|
if 'CheckGeneratedFiles' in extra_tokens:
|
2018-05-18 11:36:55 +00:00
|
|
|
env['PATH'] = '%s:%%(PATH)s' % skia_dir.join('bin')
|
2018-05-14 16:50:38 +00:00
|
|
|
api.run(api.python,
|
|
|
|
'fetch-clang-format',
|
2018-05-18 11:36:55 +00:00
|
|
|
script=skia_dir.join('bin', 'fetch-clang-format'),
|
2018-05-14 16:50:38 +00:00
|
|
|
infra_step=True)
|
|
|
|
|
|
|
|
with api.env(env):
|
|
|
|
api.run(api.step, 'gn gen',
|
|
|
|
cmd=[gn, 'gen', out_dir, '--args=' + gn_args])
|
2018-09-07 18:21:43 +00:00
|
|
|
api.run(api.step, 'ninja', cmd=['ninja', '-C', out_dir])
|
2018-05-14 16:50:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
def copy_extra_build_products(api, src, dst):
|
2018-08-03 14:07:47 +00:00
|
|
|
extra_tokens = api.vars.extra_tokens
|
|
|
|
os = api.vars.builder_cfg.get('os', '')
|
|
|
|
|
|
|
|
if 'SwiftShader' in extra_tokens:
|
2018-05-14 16:50:38 +00:00
|
|
|
util.copy_whitelisted_build_products(api,
|
2018-05-16 13:34:07 +00:00
|
|
|
src.join('swiftshader_out'),
|
2018-06-01 14:08:53 +00:00
|
|
|
api.vars.swarming_out_dir.join('swiftshader_out'))
|
2018-08-03 14:07:47 +00:00
|
|
|
|
|
|
|
if os == 'Mac' and any('SAN' in t for t in extra_tokens):
|
|
|
|
# Hardcoding this path because it should only change when we upgrade to a
|
|
|
|
# new Xcode.
|
|
|
|
lib_dir = api.vars.cache_dir.join(
|
|
|
|
'Xcode.app', 'Contents', 'Developer', 'Toolchains',
|
|
|
|
'XcodeDefault.xctoolchain', 'usr', 'lib', 'clang', XCODE_CLANG_VERSION,
|
|
|
|
'lib', 'darwin')
|
|
|
|
dylibs = api.file.glob_paths('find xSAN dylibs', lib_dir,
|
|
|
|
'libclang_rt.*san_osx_dynamic.dylib',
|
|
|
|
test_data=[
|
|
|
|
'libclang_rt.asan_osx_dynamic.dylib',
|
|
|
|
'libclang_rt.tsan_osx_dynamic.dylib',
|
|
|
|
'libclang_rt.ubsan_osx_dynamic.dylib',
|
|
|
|
])
|
|
|
|
for f in dylibs:
|
|
|
|
api.file.copy('copy %s' % api.path.basename(f), f, dst)
|