mirror of
https://fuchsia.googlesource.com/third_party/pigweed.googlesource.com/pigweed/pigweed
synced 2024-09-20 22:00:58 +00:00
edd2f148be
This change replaces the implicit overrides of the default GN target types in BUILDCONFIG.gn with explicit pw_* versions. This is done to allow Pigweed to build within larger GN projects without modifying their BUILDCONFIG files. Change-Id: I1d1e41d5e9bde8fe076f7031f3c2b98b9630ff70
56 lines
2.6 KiB
Plaintext
56 lines
2.6 KiB
Plaintext
# Copyright 2020 The Pigweed Authors
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
# use this file except in compliance with the License. You may obtain a copy of
|
|
# the License at
|
|
#
|
|
# https://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations under
|
|
# the License.
|
|
|
|
# This BUILDCONFIG file tells GN how to build upstream Pigweed. When starting a
|
|
# new project, you'll need to copy this file to your project and then modify it
|
|
# to fit your needs. Due to the way Pigweed handles file imports, you won't be
|
|
# able to simply import this file in your own BUILDCONFIG.gn.
|
|
#
|
|
# Keep in mind when importing .gni files that `gn format` will try to
|
|
# alphabetically sort imports unless they're separated by comments. For this
|
|
# file, import order matters (modules.gni MUST be imported first).
|
|
|
|
declare_args() {
|
|
# Location of the Pigweed modules directory (defaults to the directory of
|
|
# this file). When copying this buildconfig into a new project, this should
|
|
# be modified to point to the location of the Pigweed repository.
|
|
dir_pigweed = get_path_info(get_path_info("BUILDCONFIG.gn", "abspath"), "dir")
|
|
|
|
# Path to the Pigweed variables config file for the build target.
|
|
#
|
|
# When this is changed, you must run `ninja -t clean` to remove any files from
|
|
# the previous target's build before building again.
|
|
pw_target_config = "$dir_pigweed/targets/host/target_config.gni"
|
|
}
|
|
|
|
# Import variables that provide paths to modules. Pigweed's GN build requires
|
|
# that this file is imported, and it MUST be imported before any other Pigweed
|
|
# .gni files (as they depend on the dir_[module] variables).
|
|
import("$dir_pigweed/modules.gni")
|
|
|
|
# Import target configuration. This is what "completes" a Pigweed configuration.
|
|
# This file should set a default toolchain, configure pw_executable, select
|
|
# backends to build against, and provide target-specific build arguments.
|
|
import(pw_target_config)
|
|
|
|
# Ensure some sort of default toolchain was provided by the target, and then
|
|
# set the default toolchain.
|
|
assert(pw_target_toolchain != "",
|
|
"Build target must provide its own toolchain.")
|
|
|
|
# The default toolchain is not used in Pigweed builds, so it is set to a dummy
|
|
# toolchain. The top-level BUILD.gn should stamp a group with all of the build
|
|
# targets and their toolchains.
|
|
set_default_toolchain("$dir_pw_toolchain/dummy")
|