213 lines
6.0 KiB
Plaintext
213 lines
6.0 KiB
Plaintext
# Copyright 2021 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("//build_overrides/pigweed.gni")
|
|
|
|
import("$dir_pw_build/facade.gni")
|
|
import("$dir_pw_build/module_config.gni")
|
|
import("$dir_pw_docgen/docs.gni")
|
|
import("$dir_pw_unit_test/test.gni")
|
|
import("backend.gni")
|
|
|
|
declare_args() {
|
|
# The build target that overrides the default configuration options for this
|
|
# module. This should point to a source set that provides defines through a
|
|
# public config (which may -include a file or add defines directly).
|
|
pw_assert_CONFIG = pw_build_DEFAULT_MODULE_CONFIG
|
|
}
|
|
|
|
config("public_include_path") {
|
|
include_dirs = [ "public" ]
|
|
visibility = [ ":*" ]
|
|
}
|
|
|
|
config("lite_backend_overrides") {
|
|
include_dirs = [ "assert_lite_public_overrides" ]
|
|
visibility = [ ":*" ]
|
|
}
|
|
|
|
config("print_and_abort_backend_overrides") {
|
|
include_dirs = [ "print_and_abort_public_overrides" ]
|
|
visibility = [ ":*" ]
|
|
}
|
|
|
|
pw_source_set("config") {
|
|
public = [ "public/pw_assert/config.h" ]
|
|
public_configs = [ ":public_include_path" ]
|
|
public_deps = [ pw_assert_CONFIG ]
|
|
}
|
|
|
|
# Depending on dir_pw_assert provides both assert and check.
|
|
group("pw_assert") {
|
|
public_deps = [
|
|
":assert",
|
|
":check",
|
|
":config",
|
|
]
|
|
}
|
|
|
|
# Wrap :pw_assert with facade-style targets, so it can be used as if it were
|
|
# created with pw_facade.
|
|
group("facade") {
|
|
public_deps = [
|
|
":assert",
|
|
":check.facade",
|
|
]
|
|
}
|
|
|
|
group("pw_assert.facade") {
|
|
public_deps = [ ":facade" ]
|
|
}
|
|
|
|
# Provides the rich PW_CHECK macros.
|
|
pw_facade("check") {
|
|
backend = pw_assert_BACKEND
|
|
public_configs = [ ":public_include_path" ]
|
|
public = [
|
|
"public/pw_assert/check.h",
|
|
"public/pw_assert/internal/check_impl.h",
|
|
"public/pw_assert/short.h",
|
|
]
|
|
public_deps = [
|
|
":config",
|
|
dir_pw_preprocessor,
|
|
]
|
|
|
|
require_link_deps = [ ":impl" ]
|
|
}
|
|
|
|
# Provide "pw_assert/assert.h" in its own source set, so it can be used without
|
|
# depending on pw_assert_BACKEND.
|
|
pw_facade("assert") {
|
|
backend = pw_assert_LITE_BACKEND
|
|
public_configs = [ ":public_include_path" ]
|
|
public = [ "public/pw_assert/assert.h" ]
|
|
public_deps = [ ":config" ]
|
|
}
|
|
|
|
# This backend to pw_assert's PW_ASSERT()/PW_DASSERT() macros provides backwards
|
|
# compatibility with pw_assert's previous C-symbol based API.
|
|
#
|
|
# Warning: The "lite" naming is transitional. assert_lite_backend.h headers
|
|
# will be renamed as the pw_assert API is reassessed. (pwbug/246)
|
|
pw_source_set("lite_compatibility_backend") {
|
|
public_configs = [ ":lite_backend_overrides" ]
|
|
public_deps = [ dir_pw_preprocessor ]
|
|
public =
|
|
[ "assert_lite_public_overrides/pw_assert_backend/assert_lite_backend.h" ]
|
|
}
|
|
|
|
group("lite_compatibility_backend.impl") {
|
|
}
|
|
|
|
# This backend to pw_assert's PW_ASSERT()/PW_DASSERT() macros prints the assert
|
|
# expression, file/line number, and function with printf, then aborts. It is
|
|
# intended for use with host builds.
|
|
#
|
|
# Warning: The "lite" naming is transitional. assert_lite_backend.h headers
|
|
# will be renamed as the pw_assert API is reassessed. (pwbug/246)
|
|
pw_source_set("print_and_abort") {
|
|
public_configs = [
|
|
":print_and_abort_backend_overrides",
|
|
":public_include_path",
|
|
]
|
|
public_deps = [
|
|
":config",
|
|
dir_pw_preprocessor,
|
|
]
|
|
public = [
|
|
"print_and_abort_public_overrides/pw_assert_backend/assert_lite_backend.h",
|
|
]
|
|
sources = [ "public/pw_assert/internal/print_and_abort.h" ]
|
|
}
|
|
|
|
group("print_and_abort.impl") {
|
|
}
|
|
|
|
# pw_assert is low-level and ubiquitous. Because of this, it can often cause
|
|
# circular dependencies. This target collects dependencies from the backend that
|
|
# cannot be used because they would cause circular deps.
|
|
#
|
|
# This group ("$dir_pw_assert:impl") must listed in pw_build_LINK_DEPS if
|
|
# pw_assert_BACKEND is set.
|
|
#
|
|
# pw_assert backends must provide their own "impl" target that collects their
|
|
# actual dependencies. The backend "impl" group may be empty if everything can
|
|
# go directly in the backend target without causing circular dependencies.
|
|
group("impl") {
|
|
public_deps = []
|
|
|
|
if (pw_assert_BACKEND != "") {
|
|
public_deps +=
|
|
[ get_label_info(pw_assert_BACKEND, "label_no_toolchain") + ".impl" ]
|
|
}
|
|
if (pw_assert_LITE_BACKEND != "") {
|
|
public_deps += [ get_label_info(pw_assert_LITE_BACKEND,
|
|
"label_no_toolchain") + ".impl" ]
|
|
}
|
|
}
|
|
|
|
# Note: While this is technically a test, doesn't verify any of the output and
|
|
# is more of a compile test. The results can be visually verified if desired.
|
|
pw_test("assert_test") {
|
|
configs = [ ":public_include_path" ]
|
|
sources = [ "assert_test.cc" ]
|
|
deps = [ ":pw_assert" ]
|
|
}
|
|
|
|
pw_test_group("tests") {
|
|
tests = [
|
|
":assert_test",
|
|
":assert_backend_compile_test",
|
|
":assert_facade_test",
|
|
]
|
|
}
|
|
|
|
# The assert facade test doesn't require a backend since a fake one is
|
|
# provided. However, since this doesn't depend on the backend it re-includes
|
|
# the facade headers.
|
|
pw_test("assert_facade_test") {
|
|
configs = [ ":public_include_path" ] # For internal/assert_impl.h
|
|
sources = [
|
|
"assert_facade_test.cc",
|
|
"fake_backend.cc",
|
|
"public/pw_assert/internal/check_impl.h",
|
|
"pw_assert_test/fake_backend.h",
|
|
]
|
|
deps = [
|
|
":assert",
|
|
dir_pw_status,
|
|
]
|
|
|
|
# TODO(frolv): Fix this test on the QEMU target.
|
|
enable_if = pw_build_EXECUTABLE_TARGET_TYPE != "lm3s6965evb_executable"
|
|
}
|
|
|
|
pw_test("assert_backend_compile_test") {
|
|
enable_if = pw_assert_BACKEND != ""
|
|
deps = [
|
|
":pw_assert",
|
|
dir_pw_status,
|
|
pw_assert_BACKEND,
|
|
]
|
|
sources = [
|
|
"assert_backend_compile_test.cc",
|
|
"assert_backend_compile_test_c.c",
|
|
]
|
|
}
|
|
|
|
pw_doc_group("docs") {
|
|
sources = [ "docs.rst" ]
|
|
}
|