Christian Blichmann 51799f99ae Introduce a transitional logging utility library
Instead of calling `google::InitGoogleLogging()` directly, introduce an
indirection via a new utility library. After this change, Sandboxed API
should consistently use `sapi::InitLogging()` everywhere.

For now, `sapi::InitLogging()` simply calls its glog equivalent. However,
this enables us to migrate away from the gflags dependency and use Abseil
flags. Once a follow-up change lands, `sapi::InitLogging()` will instead
initialize the google logging library with flags defined from Aseil.

Later still, once Abseil releases logging, we can then drop the glog
dependency entirely.

PiperOrigin-RevId: 445363592
Change-Id: Ia23a7dc88b8ffe65a422ea4d5233bba7bdd1303a
2022-04-29 02:14:06 -07:00

274 lines
6.9 KiB
Python

# Copyright 2019 Google LLC
#
# 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.
load("//sandboxed_api/bazel:build_defs.bzl", "sapi_platform_copts")
load("//sandboxed_api/bazel:proto.bzl", "sapi_proto_library")
package(default_visibility = [
"//sandboxed_api:__subpackages__",
"//security/bedebox:__subpackages__",
])
licenses(["notice"])
# Another helper library with filesystem and path utility functions.
cc_library(
name = "file_base",
srcs = ["path.cc"],
hdrs = ["path.h"],
copts = sapi_platform_copts(),
deps = ["@com_google_absl//absl/strings"],
)
cc_test(
name = "file_base_test",
size = "small",
srcs = ["path_test.cc"],
copts = sapi_platform_copts(),
deps = [
":file_base",
"@com_google_absl//absl/strings",
"@com_google_googletest//:gtest_main",
],
)
# String file routines
cc_library(
name = "file_helpers",
srcs = ["file_helpers.cc"],
hdrs = ["file_helpers.h"],
copts = sapi_platform_copts(),
deps = [
"@com_google_absl//absl/status",
"@com_google_absl//absl/strings",
],
)
cc_test(
name = "file_helpers_test",
size = "small",
srcs = ["file_helpers_test.cc"],
copts = sapi_platform_copts(),
deps = [
":file_helpers",
"//sandboxed_api/util:status_matchers",
"@com_google_absl//absl/strings",
"@com_google_googletest//:gtest_main",
],
)
# Portable filesystem and path utility functions
cc_library(
name = "fileops",
srcs = ["fileops.cc"],
hdrs = ["fileops.h"],
copts = sapi_platform_copts(),
deps = [
":strerror",
"@com_google_absl//absl/strings",
],
)
cc_test(
name = "fileops_test",
size = "small",
srcs = ["fileops_test.cc"],
copts = sapi_platform_copts(),
deps = [
":file_helpers",
":fileops",
"//sandboxed_api:testing",
"//sandboxed_api/util:status_matchers",
"@com_google_absl//absl/strings",
"@com_google_googletest//:gtest_main",
],
)
# Compatibility layer for Abseil's flags vs. gFlags
cc_library(
name = "flags",
hdrs = ["flag.h"],
copts = sapi_platform_copts(),
deps = ["@com_github_gflags_gflags//:gflags"],
)
# Transitional library that helps configure glog with Abseil flags to
# avoid a dependency on gflags.
cc_library(
name = "logging",
srcs = ["logging.cc"],
hdrs = ["logging.h"],
copts = sapi_platform_copts(),
deps = [
"@com_google_glog//:glog",
],
)
# Small support library emulating verbose logging using Abseil's raw logging
# facility.
cc_library(
name = "raw_logging",
srcs = ["raw_logging.cc"],
hdrs = ["raw_logging.h"],
copts = sapi_platform_copts(),
deps = [
":strerror",
"//sandboxed_api:config",
"@com_google_absl//absl/base:config",
"@com_google_absl//absl/base:core_headers",
"@com_google_absl//absl/base:log_severity",
"@com_google_absl//absl/strings",
"@com_google_absl//absl/strings:str_format",
],
)
cc_library(
name = "runfiles",
srcs = ["runfiles_bazel.cc"],
hdrs = ["runfiles.h"],
copts = sapi_platform_copts(),
visibility = ["//visibility:public"],
deps = [
":file_base",
":flags",
":raw_logging",
"@bazel_tools//tools/cpp/runfiles",
"@com_google_absl//absl/strings",
"@com_google_absl//absl/strings:str_format",
],
)
sapi_proto_library(
name = "status_proto",
srcs = ["status.proto"],
)
# Implementations of utility functions not released with absl::Status.
cc_library(
name = "status",
srcs = ["status.cc"],
hdrs = [
"status.h",
"status_macros.h",
],
copts = sapi_platform_copts(),
visibility = ["//visibility:public"],
deps = [
":status_cc_proto",
":strerror",
"@com_google_absl//absl/base:core_headers",
"@com_google_absl//absl/status",
"@com_google_absl//absl/strings",
],
)
# gMock matchers for absl::Status and absl::StatusOr<T> and a gUnit printer
# extension. Adapted from the version in Asylo.
cc_library(
name = "status_matchers",
testonly = 1,
hdrs = ["status_matchers.h"],
copts = sapi_platform_copts(),
visibility = ["//visibility:public"],
deps = [
":status",
"@com_google_absl//absl/status",
"@com_google_absl//absl/status:statusor",
"@com_google_absl//absl/types:optional",
"@com_google_googletest//:gtest",
],
)
# Tests for the Status utility.
cc_test(
name = "status_test",
srcs = ["status_test.cc"],
copts = sapi_platform_copts(),
deps = [
":status",
":status_matchers",
"@com_google_absl//absl/status",
"@com_google_googletest//:gtest_main",
],
)
# Tests for the Status macros.
cc_test(
name = "status_macros_test",
srcs = ["status_macros_test.cc"],
copts = sapi_platform_copts(),
deps = [
":status",
":status_matchers",
"@com_google_absl//absl/memory",
"@com_google_absl//absl/status",
"@com_google_absl//absl/status:statusor",
"@com_google_absl//absl/strings",
"@com_google_googletest//:gtest_main",
],
)
# Internal thread-safe helper to format system error messages. Mostly
# equivalent to base/strerror.h.
cc_library(
name = "strerror",
srcs = ["strerror.cc"],
hdrs = ["strerror.h"],
copts = sapi_platform_copts(),
deps = [
"@com_google_absl//absl/base:core_headers",
"@com_google_absl//absl/strings:str_format",
],
)
cc_test(
name = "strerror_test",
srcs = ["strerror_test.cc"],
copts = sapi_platform_copts(),
deps = [
":strerror",
"@com_google_absl//absl/strings",
"@com_google_googletest//:gtest_main",
],
)
cc_library(
name = "temp_file",
srcs = ["temp_file.cc"],
hdrs = ["temp_file.h"],
copts = sapi_platform_copts(),
deps = [
":fileops",
":status",
":strerror",
"@com_google_absl//absl/status",
"@com_google_absl//absl/status:statusor",
"@com_google_absl//absl/strings",
],
)
cc_test(
name = "temp_file_test",
srcs = ["temp_file_test.cc"],
copts = sapi_platform_copts(),
deps = [
":file_base",
":fileops",
":temp_file",
"//sandboxed_api:testing",
"//sandboxed_api/util:status_matchers",
"@com_google_googletest//:gtest_main",
],
)