// Copyright 2022 The Abseil 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. // // ----------------------------------------------------------------------------- // File: log/log_entry.h // ----------------------------------------------------------------------------- // // This header declares `class absl::LogEntry`, which represents a log record as // passed to `LogSink::Send`. Data returned by pointer or by reference or by // `absl::string_view` must be copied if they are needed after the lifetime of // the `absl::LogEntry`. #ifndef ABSL_LOG_LOG_ENTRY_H_ #define ABSL_LOG_LOG_ENTRY_H_ #include <cstddef> #include <string> #include "absl/base/attributes.h" #include "absl/base/config.h" #include "absl/base/log_severity.h" #include "absl/log/internal/config.h" #include "absl/strings/string_view.h" #include "absl/time/time.h" #include "absl/types/span.h" namespace absl { ABSL_NAMESPACE_BEGIN namespace log_internal { // Test only friend. class LogEntryTestPeer; class LogMessage; } // namespace log_internal // LogEntry // // Represents a single entry in a log, i.e., one `LOG` statement or failed // `CHECK`. // // `LogEntry` is thread-compatible. class LogEntry final { … }; ABSL_NAMESPACE_END } // namespace absl #endif // ABSL_LOG_LOG_ENTRY_H_