1*61c4878aSAndroid Build Coastguard Worker# Copyright 2020 The Pigweed Authors 2*61c4878aSAndroid Build Coastguard Worker# 3*61c4878aSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); you may not 4*61c4878aSAndroid Build Coastguard Worker# use this file except in compliance with the License. You may obtain a copy of 5*61c4878aSAndroid Build Coastguard Worker# the License at 6*61c4878aSAndroid Build Coastguard Worker# 7*61c4878aSAndroid Build Coastguard Worker# https://www.apache.org/licenses/LICENSE-2.0 8*61c4878aSAndroid Build Coastguard Worker# 9*61c4878aSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*61c4878aSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 11*61c4878aSAndroid Build Coastguard Worker# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 12*61c4878aSAndroid Build Coastguard Worker# License for the specific language governing permissions and limitations under 13*61c4878aSAndroid Build Coastguard Worker# the License. 14*61c4878aSAndroid Build Coastguard Worker 15*61c4878aSAndroid Build Coastguard Workerimport("python_action.gni") 16*61c4878aSAndroid Build Coastguard Worker 17*61c4878aSAndroid Build Coastguard Worker# Prints an error message and exits the build unsuccessfully. Either 'message' 18*61c4878aSAndroid Build Coastguard Worker# or 'message_lines' must be specified, but not both. 19*61c4878aSAndroid Build Coastguard Worker# 20*61c4878aSAndroid Build Coastguard Worker# Args: 21*61c4878aSAndroid Build Coastguard Worker# 22*61c4878aSAndroid Build Coastguard Worker# message: The message to print. Use \n for newlines. 23*61c4878aSAndroid Build Coastguard Worker# message_lines: List of lines to use for the message. 24*61c4878aSAndroid Build Coastguard Worker# visibility: GN visibility to apply to the underlying target. 25*61c4878aSAndroid Build Coastguard Worker# 26*61c4878aSAndroid Build Coastguard Workertemplate("pw_error") { 27*61c4878aSAndroid Build Coastguard Worker assert( 28*61c4878aSAndroid Build Coastguard Worker defined(invoker.message) != defined(invoker.message_lines), 29*61c4878aSAndroid Build Coastguard Worker "pw_error requires either a 'message' string or a 'message_lines' list") 30*61c4878aSAndroid Build Coastguard Worker 31*61c4878aSAndroid Build Coastguard Worker if (defined(invoker.message_lines)) { 32*61c4878aSAndroid Build Coastguard Worker _message = string_join("\n", invoker.message_lines) 33*61c4878aSAndroid Build Coastguard Worker } else { 34*61c4878aSAndroid Build Coastguard Worker _message = invoker.message 35*61c4878aSAndroid Build Coastguard Worker } 36*61c4878aSAndroid Build Coastguard Worker assert(_message != "", "The message cannot be empty") 37*61c4878aSAndroid Build Coastguard Worker 38*61c4878aSAndroid Build Coastguard Worker action(target_name) { 39*61c4878aSAndroid Build Coastguard Worker script = "$dir_pw_build/py/pw_build/error.py" 40*61c4878aSAndroid Build Coastguard Worker args = [ 41*61c4878aSAndroid Build Coastguard Worker "--target", 42*61c4878aSAndroid Build Coastguard Worker get_label_info(":$target_name", "label_with_toolchain"), 43*61c4878aSAndroid Build Coastguard Worker "--message", 44*61c4878aSAndroid Build Coastguard Worker _message, 45*61c4878aSAndroid Build Coastguard Worker "--root", 46*61c4878aSAndroid Build Coastguard Worker rebase_path("//", root_build_dir), 47*61c4878aSAndroid Build Coastguard Worker "--out", 48*61c4878aSAndroid Build Coastguard Worker ".", 49*61c4878aSAndroid Build Coastguard Worker ] 50*61c4878aSAndroid Build Coastguard Worker 51*61c4878aSAndroid Build Coastguard Worker # This output file is never created. 52*61c4878aSAndroid Build Coastguard Worker outputs = [ "$target_gen_dir/$target_name.build_error" ] 53*61c4878aSAndroid Build Coastguard Worker 54*61c4878aSAndroid Build Coastguard Worker forward_variables_from(invoker, [ "visibility" ]) 55*61c4878aSAndroid Build Coastguard Worker } 56*61c4878aSAndroid Build Coastguard Worker} 57*61c4878aSAndroid Build Coastguard Worker 58*61c4878aSAndroid Build Coastguard Worker# An assert that is evaluated at build time. The assertion is only checked if 59*61c4878aSAndroid Build Coastguard Worker# this target is depended on by another target. If the assertion passes, nothing 60*61c4878aSAndroid Build Coastguard Worker# happens. If it fails, the target prints an error message with pw_error. 61*61c4878aSAndroid Build Coastguard Worker# 62*61c4878aSAndroid Build Coastguard Worker# To enforce a pw_build_assert, targets add a dependency on a pw_build_assert. 63*61c4878aSAndroid Build Coastguard Worker# Multiple targets may depend on the same pw_build_assert if the same assertion 64*61c4878aSAndroid Build Coastguard Worker# applies. 65*61c4878aSAndroid Build Coastguard Worker# 66*61c4878aSAndroid Build Coastguard Worker# Args: 67*61c4878aSAndroid Build Coastguard Worker# 68*61c4878aSAndroid Build Coastguard Worker# condition: The assertion to verify. 69*61c4878aSAndroid Build Coastguard Worker# message: The message to print. Use \n for newlines. 70*61c4878aSAndroid Build Coastguard Worker# message_lines: List of lines to use for the message. 71*61c4878aSAndroid Build Coastguard Worker# visibility: GN visibility to apply to the underlying target. 72*61c4878aSAndroid Build Coastguard Worker# 73*61c4878aSAndroid Build Coastguard Workertemplate("pw_build_assert") { 74*61c4878aSAndroid Build Coastguard Worker assert(defined(invoker.condition), 75*61c4878aSAndroid Build Coastguard Worker "pw_build_assert requires a boolean condition") 76*61c4878aSAndroid Build Coastguard Worker assert(defined(invoker.message) != defined(invoker.message_lines), 77*61c4878aSAndroid Build Coastguard Worker "pw_build_assert requires either 'message' or 'message_lines'") 78*61c4878aSAndroid Build Coastguard Worker 79*61c4878aSAndroid Build Coastguard Worker _pw_error_variables = [ 80*61c4878aSAndroid Build Coastguard Worker "message", 81*61c4878aSAndroid Build Coastguard Worker "message_lines", 82*61c4878aSAndroid Build Coastguard Worker "visibility", 83*61c4878aSAndroid Build Coastguard Worker ] 84*61c4878aSAndroid Build Coastguard Worker 85*61c4878aSAndroid Build Coastguard Worker if (invoker.condition) { 86*61c4878aSAndroid Build Coastguard Worker not_needed(invoker, _pw_error_variables) 87*61c4878aSAndroid Build Coastguard Worker group(target_name) { 88*61c4878aSAndroid Build Coastguard Worker forward_variables_from(invoker, [ "visibility" ]) 89*61c4878aSAndroid Build Coastguard Worker } 90*61c4878aSAndroid Build Coastguard Worker } else { 91*61c4878aSAndroid Build Coastguard Worker pw_error(target_name) { 92*61c4878aSAndroid Build Coastguard Worker forward_variables_from(invoker, _pw_error_variables) 93*61c4878aSAndroid Build Coastguard Worker } 94*61c4878aSAndroid Build Coastguard Worker } 95*61c4878aSAndroid Build Coastguard Worker} 96