Current copy is cloned using hash: 51694fd33cdaaec5bdd7ab3dc4f488f5818fd870 .git and .gitignore have been cleanup. tests,docs,webgpu-cts folders have been deleted. For more details look at third_party/dawn/tnt/README.md file, which will be pushed in subsequent patch.
185 lines
7.0 KiB
Plaintext
185 lines
7.0 KiB
Plaintext
# Copyright 2019 The Dawn & Tint Authors
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
#
|
|
# 1. Redistributions of source code must retain the above copyright notice, this
|
|
# list of conditions and the following disclaimer.
|
|
#
|
|
# 2. 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.
|
|
#
|
|
# 3. Neither the name of the copyright holder 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 HOLDER 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.
|
|
|
|
import("//build_overrides/build.gni")
|
|
import("dawn_features.gni")
|
|
import("dawn_overrides_with_defaults.gni")
|
|
|
|
###############################################################################
|
|
# Template to produce a component for one of Dawn's libraries.
|
|
###############################################################################
|
|
|
|
# Template that produces static and shared versions of the same library as well
|
|
# as a target similar to Chromium's component targets.
|
|
# - The shared version exports symbols and has dependent import the symbols
|
|
# as libdawn_${name}.so. If the target name matches the package directory
|
|
# name, then the shared library target will be named 'shared', otherwise
|
|
# '${target_name}_shared'.
|
|
# - The static library doesn't export symbols nor make dependents import them.
|
|
# If the target name matches the package directory name, then the static
|
|
# library target will be named 'static', otherwise '${target_name}_static'.
|
|
# - The libname target is similar to a Chromium component and is an alias for
|
|
# either the static or the shared library.
|
|
#
|
|
# The DEFINE_PREFIX must be provided and must match the respective "_export.h"
|
|
# file.
|
|
#
|
|
# Example usage:
|
|
#
|
|
# dawn_component("my_library") {
|
|
# // my_library_export.h must use the MY_LIBRARY_IMPLEMENTATION and
|
|
# // MY_LIBRARY_SHARED_LIBRARY macros.
|
|
# DEFINE_PREFIX = "MY_LIBRARY"
|
|
#
|
|
# sources = [...]
|
|
# deps = [...]
|
|
# configs = [...]
|
|
# }
|
|
#
|
|
# executable("foo") {
|
|
# deps = [ ":my_library_shared" ] // or :my_library for the same effect
|
|
# }
|
|
template("dawn_component") {
|
|
# Copy the target_name in the local scope so it doesn't get shadowed in the
|
|
# definition of targets.
|
|
name = target_name
|
|
|
|
prefix = "${name}_"
|
|
|
|
# Remove prefix if the target name matches directory
|
|
if (get_label_info(get_label_info(":$target_name", "dir"), "name") == name) {
|
|
prefix = ""
|
|
}
|
|
|
|
# The config that will apply to dependents of the shared library so they know
|
|
# they should "import" the symbols
|
|
config("${prefix}shared_public_config") {
|
|
defines = [ "${invoker.DEFINE_PREFIX}_SHARED_LIBRARY" ]
|
|
|
|
# Executable needs an rpath to find our shared libraries on OSX and Linux
|
|
if (is_mac) {
|
|
ldflags = [
|
|
"-rpath",
|
|
"@executable_path/",
|
|
]
|
|
}
|
|
if ((is_linux || is_chromeos) && dawn_has_build) {
|
|
configs = [ "//build/config/gcc:rpath_for_built_shared_libraries" ]
|
|
}
|
|
}
|
|
|
|
shared_library("${prefix}shared") {
|
|
# The "tool" for creating shared libraries will automatically add the "lib" prefix
|
|
output_name = "dawn_${name}"
|
|
|
|
# Copy all variables except "configs", which has a default value
|
|
forward_variables_from(invoker, "*", [ "configs" ])
|
|
if (defined(invoker.configs)) {
|
|
configs += invoker.configs
|
|
}
|
|
|
|
# If a "build with ARC" config is present, remove it.
|
|
if (filter_include(configs, [ "//build/config/compiler:enable_arc" ]) !=
|
|
[]) {
|
|
configs -= [ "//build/config/compiler:enable_arc" ]
|
|
}
|
|
|
|
# Tell dependents where to find this shared library
|
|
if (is_mac) {
|
|
ldflags = [
|
|
"-install_name",
|
|
"@rpath/lib${name}.dylib",
|
|
]
|
|
}
|
|
|
|
# Use the config that makes the ${DEFINE_PREFIX}_EXPORT macro do something
|
|
if (!defined(public_configs)) {
|
|
public_configs = []
|
|
}
|
|
public_configs += [ ":${prefix}shared_public_config" ]
|
|
|
|
# Tell sources of this library to export the symbols (and not import)
|
|
if (!defined(defines)) {
|
|
defines = []
|
|
}
|
|
defines += [ "${invoker.DEFINE_PREFIX}_IMPLEMENTATION" ]
|
|
|
|
# Chromium adds a config that uses a special linker script that removes
|
|
# all symbols except JNI ones. Remove this config so that our
|
|
# shared_library symbols are visible. This matches what Chromium's
|
|
# component template does.
|
|
if (build_with_chromium && is_android) {
|
|
configs -= [ "//build/config/android:hide_all_but_jni_onload" ]
|
|
}
|
|
}
|
|
|
|
if (dawn_complete_static_libs) {
|
|
# Use static_library if explicitly requested - this works even if there are
|
|
# no sources in the target by linking in sources from all dependencies.
|
|
_static_target_type = "static_library"
|
|
} else if (!defined(invoker.sources) || invoker.sources == []) {
|
|
# When there are no sources defined, use a source set to avoid creating
|
|
# an empty static library (which generally don't work).
|
|
_static_target_type = "source_set"
|
|
} else {
|
|
# Use static libraries for the static build rather than source sets because
|
|
# many of of our test binaries link many large dependencies but often don't
|
|
# use large portions of them. The static libraries are much more efficient
|
|
# in this situation since only the necessary object files are linked.
|
|
_static_target_type = "static_library"
|
|
}
|
|
|
|
target(_static_target_type, "${prefix}static") {
|
|
output_name = "dawn_${name}_static"
|
|
|
|
if (dawn_complete_static_libs) {
|
|
assert(_static_target_type == "static_library")
|
|
complete_static_lib = true
|
|
}
|
|
|
|
# Copy all variables except "configs", which has a default value
|
|
forward_variables_from(invoker, "*", [ "configs" ])
|
|
if (defined(invoker.configs)) {
|
|
configs += invoker.configs
|
|
}
|
|
|
|
# If a "build with ARC" config is present, remove it.
|
|
if (filter_include(configs, [ "//build/config/compiler:enable_arc" ]) !=
|
|
[]) {
|
|
configs -= [ "//build/config/compiler:enable_arc" ]
|
|
}
|
|
}
|
|
|
|
group(name) {
|
|
if (is_component_build) {
|
|
public_deps = [ ":${prefix}shared" ]
|
|
} else {
|
|
public_deps = [ ":${prefix}static" ]
|
|
}
|
|
}
|
|
}
|