aboutsummaryrefslogtreecommitdiff
path: root/pw_build/error.gni
blob: 33804c982ac97c92e256287afe07b40579aa2e43 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# 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)
    }
  }
}