| # 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.") |
| set_default_toolchain("$dir_pw_toolchain/dummy") |
| |
| # Override the built-in build targets to add default compilation options. |
| # TODO(pwbug/72): Move this code to a .gni file for easier reuse. |
| template("_pw_override_target_with_defaults") { |
| # Set the default variables for GN targets. |
| import("$dir_pw_build/defaults.gni") |
| target(invoker._target_type, target_name) { |
| _supported_default_variables = [ |
| "configs", |
| "public_deps", |
| ] |
| forward_variables_from(invoker, |
| "*", |
| [ "_target_type" ] + _supported_default_variables) |
| |
| if (defined(pw_build_defaults.configs)) { |
| configs = pw_build_defaults.configs |
| } else { |
| configs = [] |
| } |
| if (defined(remove_configs)) { |
| if (remove_configs[0] == "*") { |
| configs = [] |
| } else { |
| configs -= remove_configs |
| } |
| } |
| if (defined(invoker.configs)) { |
| configs += invoker.configs |
| } |
| |
| if (defined(pw_build_defaults.public_deps)) { |
| public_deps = pw_build_defaults.public_deps |
| } else { |
| public_deps = [] |
| } |
| if (defined(remove_public_deps)) { |
| if (remove_public_deps[0] == "*") { |
| public_deps = [] |
| } else { |
| public_deps -= remove_public_deps |
| } |
| } |
| if (defined(invoker.public_deps)) { |
| public_deps += invoker.public_deps |
| } |
| } |
| } |
| |
| foreach(_target_type, |
| [ |
| "source_set", |
| "executable", |
| "shared_library", |
| "static_library", |
| ]) { |
| template(_target_type) { |
| _pw_override_target_with_defaults(target_name) { |
| forward_variables_from(invoker, "*") |
| } |
| } |
| } |