blob: d51a510adfeba516e8cb13219048cf9b8c7b7ba2 [file] [log] [blame]
# 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("//build_overrides/pigweed.gni")
import("$dir_pw_build/module_config.gni")
import("$dir_pw_build/target_types.gni")
import("$dir_pw_docgen/docs.gni")
import("$dir_pw_log/backend.gni")
import("$dir_pw_tokenizer/backend.gni")
import("$dir_pw_unit_test/test.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_log_tokenized_CONFIG = pw_build_DEFAULT_MODULE_CONFIG
}
config("public_includes") {
include_dirs = [ "public" ]
visibility = [ ":*" ]
}
config("backend_config") {
include_dirs = [ "public_overrides" ]
visibility = [ ":*" ]
}
# This target provides the log_tokenized.h header, which implements the pw_log
# backend.
#
# This target depends on the pw_tokenizer facade target
# (dir_pw_tokenizer:global_handler_with_payload.facade) to avoid circular
# dependencies. The dependency graph for pw_log_tokenized is the following:
#
# pw_log:facade <--- :pw_log_tokenized
# ^ \ ^ ^
# | \ / \
# -> pw_log -> :log_backend --> pw_tokenizer:global_handler_with_payload
#
pw_source_set("pw_log_tokenized") {
public_configs = [ ":public_includes" ]
public_deps = [
"$dir_pw_log:facade",
"$dir_pw_tokenizer:global_handler_with_payload.facade",
dir_pw_preprocessor,
pw_log_tokenized_CONFIG,
]
public = [
"public/pw_log_tokenized/config.h",
"public/pw_log_tokenized/log_tokenized.h",
]
}
# This target provides the backend for pw_log.
pw_source_set("log_backend") {
public_configs = [ ":backend_config" ]
public_deps = [ ":pw_log_tokenized" ]
public = [ "public_overrides/pw_log_backend/log_backend.h" ]
deps = [ "$dir_pw_tokenizer:global_handler_with_payload" ]
}
# This target provides a backend for pw_tokenizer that encodes tokenized logs as
# Base64, encodes them into HDLC frames, and writes them over sys_io.
pw_source_set("base64_over_hdlc") {
public_configs = [ ":public_includes" ]
public = [ "public/pw_log_tokenized/base64_over_hdlc.h" ]
sources = [ "base64_over_hdlc.cc" ]
deps = [
"$dir_pw_hdlc:encoder",
"$dir_pw_stream:sys_io_stream",
"$dir_pw_tokenizer:base64",
"$dir_pw_tokenizer:global_handler_with_payload.facade",
]
}
pw_test_group("tests") {
tests = [ ":log_tokenized_test" ]
}
pw_test("log_tokenized_test") {
sources = [ "test.cc" ]
deps = [ ":pw_log_tokenized" ]
}
pw_doc_group("docs") {
sources = [ "docs.rst" ]
other_deps = [ "py" ]
}