xref: /aosp_15_r20/external/pigweed/pw_build/error.gni (revision 61c4878ac05f98d0ceed94b57d316916de578985)
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