blob: df03f452343f0a25945006b2fbab99ac17448345 [file] [log] [blame] [edit]
# Copyright 2016 The Fuchsia Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
# This file directs GN to all the other key files.
# The location of the build configuration file.
buildconfig = "//build/config/BUILDCONFIG.gn"
# The secondary source root is a parallel directory tree where GN build files are placed when they
# can not be placed directly in the source tree, e.g. for third party source trees.
secondary_source = "//build/secondary/"
# The executable used to execute scripts in action and exec_script. This is often an interpreter for
# projects that use a primary scripting language. In this project, we use several different kinds of
# programs including scripts in different languages and native binaries. An empty script_executable
# string tells GN to directly run the "script".
script_executable = ""
# Require Ninja 1.10.0 to support multiple outputs from a rule with a depfile.
ninja_required_version = "1.10.0"
# Enable checking for all source code we control.
no_check_targets = [ "//third_party/*" ]
# Use of `exec_script()` is discouraged for performance reasons.
# https://fuchsia.dev/fuchsia-src/concepts/build_system/best_practices#exec-script
exec_script_whitelist = [
"//build/config/clang/clang.gni",
"//build/config/mac/mac_sdk.gni",
"//build/config/profile/BUILD.gn",
"//build/config/sanitizers/BUILD.gn",
"//build/toolchain/concurrent_jobs.gni",
"//build/toolchain/zircon/zircon_toolchain.gni",
"//zircon/kernel/arch/x86/phys/BUILD.gn",
]
check_system_includes = true
# Causes a Clang compilation database to be written to $root_build_dir/compile_commands.json. It
# will contain the compilation commands for these patterns and all of their recursive dependencies.
export_compile_commands = [ "//:default" ]
# These arguments override the default values for items in a declare_args block. "gn args" in turn
# can override these.
#
# In general the value for a build arg in a declare_args block should be the default. In some
# cases, a third party dependency will want different defaults for being built as part of Fuchsia
# vs. being built standalone. In this case, the Fuchsia defaults should go here. There should be no
# overrides here for values declared in the main Fuchsia repository.
#
# Important note for defining defaults: This file is executed before the BUILDCONFIG.gn file. That
# file sets up the global variables like "target_os". This means that the default_args can not depend
# on the platform, architecture, or other build parameters. If you really need that, the other repo
# should define a flag that toggles on a behavior that implements the additional logic required by
# Fuchsia to set the variables.
default_args = {
# Limit the visibility of Pigweed modules to Pigweed integration files and Pigweed itself. Modules
# are allowlisted in //third_party/pigweed/BUILD.gn for use in Fuchsia.
pw_build_DEFAULT_VISIBILITY = [ "//third_party/pigweed/*" ]
# Specify Pigweed backends for Fuchsia.
pw_assert_BACKEND = "//third_party/pigweed/backends/pw_assert"
pw_log_BACKEND = "//third_party/pigweed/backends/pw_log/dfv1"
pw_chrono_SYSTEM_CLOCK_BACKEND =
"//third_party/pigweed/src/pw_chrono_stl:system_clock"
# Pigweed configs for Fuchsia.
pw_function_CONFIG =
"//third_party/pigweed/backends/pw_function:define_overrides"
# Some Pigweed module implementations need to be link dependencies to avoid circular dependencies.
pw_build_LINK_DEPS = [
"//third_party/pigweed/src/pw_assert:impl",
"//third_party/pigweed/src/pw_log:impl",
]
}