xref: /aosp_15_r20/external/pigweed/pw_assert/BUILD.gn (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1*61c4878aSAndroid Build Coastguard Worker# Copyright 2021 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("//build_overrides/pigweed.gni")
16*61c4878aSAndroid Build Coastguard Worker
17*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_build/facade.gni")
18*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_build/module_config.gni")
19*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_docgen/docs.gni")
20*61c4878aSAndroid Build Coastguard Workerimport("$dir_pw_unit_test/test.gni")
21*61c4878aSAndroid Build Coastguard Workerimport("backend.gni")
22*61c4878aSAndroid Build Coastguard Worker
23*61c4878aSAndroid Build Coastguard Workerdeclare_args() {
24*61c4878aSAndroid Build Coastguard Worker  # The build target that overrides the default configuration options for this
25*61c4878aSAndroid Build Coastguard Worker  # module. This should point to a source set that provides defines through a
26*61c4878aSAndroid Build Coastguard Worker  # public config (which may -include a file or add defines directly).
27*61c4878aSAndroid Build Coastguard Worker  pw_assert_CONFIG = pw_build_DEFAULT_MODULE_CONFIG
28*61c4878aSAndroid Build Coastguard Worker}
29*61c4878aSAndroid Build Coastguard Worker
30*61c4878aSAndroid Build Coastguard Workerconfig("public_include_path") {
31*61c4878aSAndroid Build Coastguard Worker  include_dirs = [ "public" ]
32*61c4878aSAndroid Build Coastguard Worker  visibility = [ ":*" ]
33*61c4878aSAndroid Build Coastguard Worker}
34*61c4878aSAndroid Build Coastguard Worker
35*61c4878aSAndroid Build Coastguard Workerconfig("assert_backend_overrides") {
36*61c4878aSAndroid Build Coastguard Worker  include_dirs = [ "assert_compatibility_public_overrides" ]
37*61c4878aSAndroid Build Coastguard Worker  visibility = [ ":*" ]
38*61c4878aSAndroid Build Coastguard Worker}
39*61c4878aSAndroid Build Coastguard Worker
40*61c4878aSAndroid Build Coastguard Workerconfig("libc_assert_overrides") {
41*61c4878aSAndroid Build Coastguard Worker  include_dirs = [ "libc_assert_public_overrides" ]
42*61c4878aSAndroid Build Coastguard Worker  visibility = [ ":*" ]
43*61c4878aSAndroid Build Coastguard Worker}
44*61c4878aSAndroid Build Coastguard Worker
45*61c4878aSAndroid Build Coastguard Workerconfig("print_and_abort_check_backend_overrides") {
46*61c4878aSAndroid Build Coastguard Worker  include_dirs = [ "print_and_abort_check_public_overrides" ]
47*61c4878aSAndroid Build Coastguard Worker  visibility = [ ":*" ]
48*61c4878aSAndroid Build Coastguard Worker}
49*61c4878aSAndroid Build Coastguard Worker
50*61c4878aSAndroid Build Coastguard Workerconfig("print_and_abort_assert_backend_overrides") {
51*61c4878aSAndroid Build Coastguard Worker  include_dirs = [ "print_and_abort_assert_public_overrides" ]
52*61c4878aSAndroid Build Coastguard Worker  visibility = [ ":*" ]
53*61c4878aSAndroid Build Coastguard Worker}
54*61c4878aSAndroid Build Coastguard Worker
55*61c4878aSAndroid Build Coastguard Workerpw_source_set("config") {
56*61c4878aSAndroid Build Coastguard Worker  public = [ "public/pw_assert/config.h" ]
57*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":public_include_path" ]
58*61c4878aSAndroid Build Coastguard Worker  public_deps = [ pw_assert_CONFIG ]
59*61c4878aSAndroid Build Coastguard Worker}
60*61c4878aSAndroid Build Coastguard Worker
61*61c4878aSAndroid Build Coastguard Worker# Depending on dir_pw_assert provides both assert and check.
62*61c4878aSAndroid Build Coastguard Workergroup("pw_assert") {
63*61c4878aSAndroid Build Coastguard Worker  public_deps = [
64*61c4878aSAndroid Build Coastguard Worker    ":assert",
65*61c4878aSAndroid Build Coastguard Worker    ":check",
66*61c4878aSAndroid Build Coastguard Worker    ":config",
67*61c4878aSAndroid Build Coastguard Worker  ]
68*61c4878aSAndroid Build Coastguard Worker}
69*61c4878aSAndroid Build Coastguard Worker
70*61c4878aSAndroid Build Coastguard Worker# Wrap :pw_assert with facade-style targets, so it can be used as if it were
71*61c4878aSAndroid Build Coastguard Worker# created with pw_facade.
72*61c4878aSAndroid Build Coastguard Workergroup("facade") {
73*61c4878aSAndroid Build Coastguard Worker  public_deps = [
74*61c4878aSAndroid Build Coastguard Worker    ":assert",
75*61c4878aSAndroid Build Coastguard Worker    ":check.facade",
76*61c4878aSAndroid Build Coastguard Worker  ]
77*61c4878aSAndroid Build Coastguard Worker}
78*61c4878aSAndroid Build Coastguard Worker
79*61c4878aSAndroid Build Coastguard Workergroup("pw_assert.facade") {
80*61c4878aSAndroid Build Coastguard Worker  public_deps = [ ":facade" ]
81*61c4878aSAndroid Build Coastguard Worker}
82*61c4878aSAndroid Build Coastguard Worker
83*61c4878aSAndroid Build Coastguard Worker# Provides the rich PW_CHECK macros.
84*61c4878aSAndroid Build Coastguard Workerpw_facade("check") {
85*61c4878aSAndroid Build Coastguard Worker  backend = pw_assert_BACKEND
86*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":public_include_path" ]
87*61c4878aSAndroid Build Coastguard Worker  public = [
88*61c4878aSAndroid Build Coastguard Worker    "public/pw_assert/check.h",
89*61c4878aSAndroid Build Coastguard Worker    "public/pw_assert/internal/check_impl.h",
90*61c4878aSAndroid Build Coastguard Worker    "public/pw_assert/short.h",
91*61c4878aSAndroid Build Coastguard Worker  ]
92*61c4878aSAndroid Build Coastguard Worker  public_deps = [
93*61c4878aSAndroid Build Coastguard Worker    ":config",
94*61c4878aSAndroid Build Coastguard Worker    dir_pw_preprocessor,
95*61c4878aSAndroid Build Coastguard Worker  ]
96*61c4878aSAndroid Build Coastguard Worker
97*61c4878aSAndroid Build Coastguard Worker  require_link_deps = [ ":impl" ]
98*61c4878aSAndroid Build Coastguard Worker}
99*61c4878aSAndroid Build Coastguard Worker
100*61c4878aSAndroid Build Coastguard Worker# Provide "pw_assert/assert.h" in its own source set, so it can be used without
101*61c4878aSAndroid Build Coastguard Worker# depending on pw_assert_BACKEND.
102*61c4878aSAndroid Build Coastguard Workerpw_facade("assert") {
103*61c4878aSAndroid Build Coastguard Worker  backend = pw_assert_LITE_BACKEND
104*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":public_include_path" ]
105*61c4878aSAndroid Build Coastguard Worker  public = [ "public/pw_assert/assert.h" ]
106*61c4878aSAndroid Build Coastguard Worker  public_deps = [ ":config" ]
107*61c4878aSAndroid Build Coastguard Worker}
108*61c4878aSAndroid Build Coastguard Worker
109*61c4878aSAndroid Build Coastguard Worker# This backend to pw_assert's PW_ASSERT()/PW_DASSERT() macros provides backwards
110*61c4878aSAndroid Build Coastguard Worker# compatibility with pw_assert's previous C-symbol based API.
111*61c4878aSAndroid Build Coastguard Worker#
112*61c4878aSAndroid Build Coastguard Worker# Warning: The assert facade is in a transitional state, and this target is
113*61c4878aSAndroid Build Coastguard Worker# likely to be removed as the pw_assert API is reassessed. (b/235149326)
114*61c4878aSAndroid Build Coastguard Workerpw_source_set("assert_compatibility_backend") {
115*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":assert_backend_overrides" ]
116*61c4878aSAndroid Build Coastguard Worker  public_deps = [ dir_pw_preprocessor ]
117*61c4878aSAndroid Build Coastguard Worker  public = [
118*61c4878aSAndroid Build Coastguard Worker    "assert_compatibility_public_overrides/pw_assert_backend/assert_backend.h",
119*61c4878aSAndroid Build Coastguard Worker  ]
120*61c4878aSAndroid Build Coastguard Worker}
121*61c4878aSAndroid Build Coastguard Worker
122*61c4878aSAndroid Build Coastguard Workergroup("assert_compatibility_backend.impl") {
123*61c4878aSAndroid Build Coastguard Worker}
124*61c4878aSAndroid Build Coastguard Worker
125*61c4878aSAndroid Build Coastguard Workerpw_source_set("libc_assert") {
126*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":public_include_path" ]
127*61c4878aSAndroid Build Coastguard Worker  public = [
128*61c4878aSAndroid Build Coastguard Worker    "libc_assert_public_overrides/assert.h",
129*61c4878aSAndroid Build Coastguard Worker    "libc_assert_public_overrides/cassert",
130*61c4878aSAndroid Build Coastguard Worker    "public/pw_assert/internal/libc_assert.h",
131*61c4878aSAndroid Build Coastguard Worker  ]
132*61c4878aSAndroid Build Coastguard Worker  public_deps = [
133*61c4878aSAndroid Build Coastguard Worker    ":assert",
134*61c4878aSAndroid Build Coastguard Worker    dir_pw_preprocessor,
135*61c4878aSAndroid Build Coastguard Worker  ]
136*61c4878aSAndroid Build Coastguard Worker}
137*61c4878aSAndroid Build Coastguard Worker
138*61c4878aSAndroid Build Coastguard Workerpw_source_set("print_and_abort") {
139*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":public_include_path" ]
140*61c4878aSAndroid Build Coastguard Worker  public_deps = [ ":config" ]
141*61c4878aSAndroid Build Coastguard Worker  public = [ "public/pw_assert/internal/print_and_abort.h" ]
142*61c4878aSAndroid Build Coastguard Worker  visibility = [ ":*" ]
143*61c4878aSAndroid Build Coastguard Worker}
144*61c4878aSAndroid Build Coastguard Worker
145*61c4878aSAndroid Build Coastguard Worker# This backend to pw_assert's PW_CHECK()/PW_DCHECK() macros prints the assert
146*61c4878aSAndroid Build Coastguard Worker# expression, evaluated expression, file/line number, function, and user message
147*61c4878aSAndroid Build Coastguard Worker# with printf, then aborts. It is intended for use with host builds.
148*61c4878aSAndroid Build Coastguard Workerpw_source_set("print_and_abort_check_backend") {
149*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":print_and_abort_check_backend_overrides" ]
150*61c4878aSAndroid Build Coastguard Worker  public_deps = [ ":print_and_abort" ]
151*61c4878aSAndroid Build Coastguard Worker  public = [
152*61c4878aSAndroid Build Coastguard Worker    "print_and_abort_check_public_overrides/pw_assert_backend/check_backend.h",
153*61c4878aSAndroid Build Coastguard Worker  ]
154*61c4878aSAndroid Build Coastguard Worker}
155*61c4878aSAndroid Build Coastguard Worker
156*61c4878aSAndroid Build Coastguard Workergroup("print_and_abort_check_backend.impl") {
157*61c4878aSAndroid Build Coastguard Worker}
158*61c4878aSAndroid Build Coastguard Worker
159*61c4878aSAndroid Build Coastguard Worker# This backend to pw_assert's PW_ASSERT()/PW_DASSERT() macros prints the assert
160*61c4878aSAndroid Build Coastguard Worker# expression, file/line number, and function with printf, then aborts. It is
161*61c4878aSAndroid Build Coastguard Worker# intended for use with host builds.
162*61c4878aSAndroid Build Coastguard Workerpw_source_set("print_and_abort_assert_backend") {
163*61c4878aSAndroid Build Coastguard Worker  public_configs = [ ":print_and_abort_assert_backend_overrides" ]
164*61c4878aSAndroid Build Coastguard Worker  public_deps = [
165*61c4878aSAndroid Build Coastguard Worker    ":config",
166*61c4878aSAndroid Build Coastguard Worker    ":print_and_abort",
167*61c4878aSAndroid Build Coastguard Worker  ]
168*61c4878aSAndroid Build Coastguard Worker  public = [ "print_and_abort_assert_public_overrides/pw_assert_backend/assert_backend.h" ]
169*61c4878aSAndroid Build Coastguard Worker}
170*61c4878aSAndroid Build Coastguard Worker
171*61c4878aSAndroid Build Coastguard Workergroup("print_and_abort_assert_backend.impl") {
172*61c4878aSAndroid Build Coastguard Worker}
173*61c4878aSAndroid Build Coastguard Worker
174*61c4878aSAndroid Build Coastguard Worker# pw_assert is low-level and ubiquitous. Because of this, it can often cause
175*61c4878aSAndroid Build Coastguard Worker# circular dependencies. This target collects dependencies from the backend that
176*61c4878aSAndroid Build Coastguard Worker# cannot be used because they would cause circular deps.
177*61c4878aSAndroid Build Coastguard Worker#
178*61c4878aSAndroid Build Coastguard Worker# This group ("$dir_pw_assert:impl") must listed in pw_build_LINK_DEPS if
179*61c4878aSAndroid Build Coastguard Worker# pw_assert_BACKEND is set.
180*61c4878aSAndroid Build Coastguard Worker#
181*61c4878aSAndroid Build Coastguard Worker# pw_assert backends must provide their own "impl" target that collects their
182*61c4878aSAndroid Build Coastguard Worker# actual dependencies. The backend "impl" group may be empty if everything can
183*61c4878aSAndroid Build Coastguard Worker# go directly in the backend target without causing circular dependencies.
184*61c4878aSAndroid Build Coastguard Workergroup("impl") {
185*61c4878aSAndroid Build Coastguard Worker  public_deps = []
186*61c4878aSAndroid Build Coastguard Worker
187*61c4878aSAndroid Build Coastguard Worker  if (pw_assert_BACKEND != "") {
188*61c4878aSAndroid Build Coastguard Worker    public_deps +=
189*61c4878aSAndroid Build Coastguard Worker        [ get_label_info(pw_assert_BACKEND, "label_no_toolchain") + ".impl" ]
190*61c4878aSAndroid Build Coastguard Worker  }
191*61c4878aSAndroid Build Coastguard Worker  if (pw_assert_LITE_BACKEND != "") {
192*61c4878aSAndroid Build Coastguard Worker    public_deps += [ get_label_info(pw_assert_LITE_BACKEND,
193*61c4878aSAndroid Build Coastguard Worker                                    "label_no_toolchain") + ".impl" ]
194*61c4878aSAndroid Build Coastguard Worker  }
195*61c4878aSAndroid Build Coastguard Worker}
196*61c4878aSAndroid Build Coastguard Worker
197*61c4878aSAndroid Build Coastguard Worker# Note: While this is technically a test, doesn't verify any of the output and
198*61c4878aSAndroid Build Coastguard Worker# is more of a compile test. The results can be visually verified if desired.
199*61c4878aSAndroid Build Coastguard Workerpw_test("assert_test") {
200*61c4878aSAndroid Build Coastguard Worker  configs = [ ":public_include_path" ]
201*61c4878aSAndroid Build Coastguard Worker  sources = [ "assert_test.cc" ]
202*61c4878aSAndroid Build Coastguard Worker  deps = [
203*61c4878aSAndroid Build Coastguard Worker    ":pw_assert",
204*61c4878aSAndroid Build Coastguard Worker    dir_pw_status,
205*61c4878aSAndroid Build Coastguard Worker  ]
206*61c4878aSAndroid Build Coastguard Worker}
207*61c4878aSAndroid Build Coastguard Worker
208*61c4878aSAndroid Build Coastguard Workerpw_test_group("tests") {
209*61c4878aSAndroid Build Coastguard Worker  tests = [
210*61c4878aSAndroid Build Coastguard Worker    ":assert_test",
211*61c4878aSAndroid Build Coastguard Worker    ":assert_backend_compile_test",
212*61c4878aSAndroid Build Coastguard Worker    ":assert_facade_test",
213*61c4878aSAndroid Build Coastguard Worker  ]
214*61c4878aSAndroid Build Coastguard Worker}
215*61c4878aSAndroid Build Coastguard Worker
216*61c4878aSAndroid Build Coastguard Worker# The assert facade test doesn't require a backend since a fake one is
217*61c4878aSAndroid Build Coastguard Worker# provided. However, since this doesn't depend on the backend it re-includes
218*61c4878aSAndroid Build Coastguard Worker# the facade headers.
219*61c4878aSAndroid Build Coastguard Workerpw_test("assert_facade_test") {
220*61c4878aSAndroid Build Coastguard Worker  configs = [ ":public_include_path" ]  # For internal/check_impl.h
221*61c4878aSAndroid Build Coastguard Worker  sources = [
222*61c4878aSAndroid Build Coastguard Worker    "assert_facade_test.cc",
223*61c4878aSAndroid Build Coastguard Worker    "fake_backend.cc",
224*61c4878aSAndroid Build Coastguard Worker    "public/pw_assert/internal/check_impl.h",
225*61c4878aSAndroid Build Coastguard Worker    "pw_assert_test/fake_backend.h",
226*61c4878aSAndroid Build Coastguard Worker  ]
227*61c4878aSAndroid Build Coastguard Worker  deps = [
228*61c4878aSAndroid Build Coastguard Worker    ":pw_assert",
229*61c4878aSAndroid Build Coastguard Worker    dir_pw_result,
230*61c4878aSAndroid Build Coastguard Worker    dir_pw_span,
231*61c4878aSAndroid Build Coastguard Worker    dir_pw_status,
232*61c4878aSAndroid Build Coastguard Worker    dir_pw_string,
233*61c4878aSAndroid Build Coastguard Worker  ]
234*61c4878aSAndroid Build Coastguard Worker  negative_compilation_tests = true
235*61c4878aSAndroid Build Coastguard Worker
236*61c4878aSAndroid Build Coastguard Worker  # TODO(frolv): Fix this test on the QEMU target.
237*61c4878aSAndroid Build Coastguard Worker  enable_if = pw_build_EXECUTABLE_TARGET_TYPE != "lm3s6965evb_executable"
238*61c4878aSAndroid Build Coastguard Worker}
239*61c4878aSAndroid Build Coastguard Worker
240*61c4878aSAndroid Build Coastguard Workerpw_test("assert_backend_compile_test") {
241*61c4878aSAndroid Build Coastguard Worker  enable_if = pw_assert_BACKEND != ""
242*61c4878aSAndroid Build Coastguard Worker  deps = [
243*61c4878aSAndroid Build Coastguard Worker    ":pw_assert",
244*61c4878aSAndroid Build Coastguard Worker    dir_pw_status,
245*61c4878aSAndroid Build Coastguard Worker    pw_assert_BACKEND,
246*61c4878aSAndroid Build Coastguard Worker  ]
247*61c4878aSAndroid Build Coastguard Worker  sources = [
248*61c4878aSAndroid Build Coastguard Worker    "assert_backend_compile_test.cc",
249*61c4878aSAndroid Build Coastguard Worker    "assert_backend_compile_test_c.c",
250*61c4878aSAndroid Build Coastguard Worker  ]
251*61c4878aSAndroid Build Coastguard Worker}
252*61c4878aSAndroid Build Coastguard Worker
253*61c4878aSAndroid Build Coastguard Workerpw_doc_group("docs") {
254*61c4878aSAndroid Build Coastguard Worker  sources = [
255*61c4878aSAndroid Build Coastguard Worker    "backends.rst",
256*61c4878aSAndroid Build Coastguard Worker    "docs.rst",
257*61c4878aSAndroid Build Coastguard Worker  ]
258*61c4878aSAndroid Build Coastguard Worker}
259