# 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. import("python_action.gni") # Prints an error message and exits the build unsuccessfully. Either 'message' # or 'message_lines' must be specified, but not both. # # Args: # # message: The message to print. Use \n for newlines. # message_lines: List of lines to use for the message. # visibility: GN visibility to apply to the underlying target. # template("pw_error") { assert( defined(invoker.message) != defined(invoker.message_lines), "pw_error requires either a 'message' string or a 'message_lines' list") if (defined(invoker.message_lines)) { _message = string_join("\n", invoker.message_lines) } else { _message = invoker.message } assert(_message != "", "The message cannot be empty") action(target_name) { script = "$dir_pw_build/py/pw_build/error.py" args = [ "--target", get_label_info(":$target_name", "label_with_toolchain"), "--message", _message, "--root", rebase_path("//", root_build_dir), "--out", ".", ] # This output file is never created. outputs = [ "$target_gen_dir/$target_name.build_error" ] forward_variables_from(invoker, [ "visibility" ]) } } # An assert that is evaluated at build time. The assertion is only checked if # this target is depended on by another target. If the assertion passes, nothing # happens. If it fails, the target prints an error message with pw_error. # # To enforce a pw_build_assert, targets add a dependency on a pw_build_assert. # Multiple targets may depend on the same pw_build_assert if the same assertion # applies. # # Args: # # condition: The assertion to verify. # message: The message to print. Use \n for newlines. # message_lines: List of lines to use for the message. # visibility: GN visibility to apply to the underlying target. # template("pw_build_assert") { assert(defined(invoker.condition), "pw_build_assert requires a boolean condition") assert(defined(invoker.message) != defined(invoker.message_lines), "pw_build_assert requires either 'message' or 'message_lines'") _pw_error_variables = [ "message", "message_lines", "visibility", ] if (invoker.condition) { not_needed(invoker, _pw_error_variables) group(target_name) { forward_variables_from(invoker, [ "visibility" ]) } } else { pw_error(target_name) { forward_variables_from(invoker, _pw_error_variables) } } }