Abseil Common Libraries (C++) (grcp 依赖)
https://abseil.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
102 lines
3.9 KiB
102 lines
3.9 KiB
2 years ago
|
// 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/internal/globals.h
|
||
|
// -----------------------------------------------------------------------------
|
||
|
//
|
||
|
// This header file contains various global objects and static helper routines
|
||
|
// use in logging implementation.
|
||
|
|
||
|
#ifndef ABSL_LOG_INTERNAL_GLOBALS_H_
|
||
|
#define ABSL_LOG_INTERNAL_GLOBALS_H_
|
||
|
|
||
|
#include "absl/base/config.h"
|
||
|
#include "absl/base/log_severity.h"
|
||
|
#include "absl/strings/string_view.h"
|
||
|
#include "absl/time/time.h"
|
||
|
|
||
|
namespace absl {
|
||
|
ABSL_NAMESPACE_BEGIN
|
||
|
namespace log_internal {
|
||
|
|
||
|
// IsInitialized returns true if the logging library is initialized.
|
||
|
// This function is async-signal-safe
|
||
|
bool IsInitialized();
|
||
|
|
||
|
// SetLoggingInitialized is called once after logging initialization is done.
|
||
|
void SetInitialized();
|
||
|
|
||
|
// Unconditionally write a `message` to stderr. If `severity` exceeds kInfo
|
||
|
// we also flush the stderr stream.
|
||
|
void WriteToStderr(absl::string_view message, absl::LogSeverity severity);
|
||
|
|
||
|
// Set the TimeZone used for human-friendly times (for example, the log message
|
||
|
// prefix) printed by the logging library. This may only be called once.
|
||
|
void SetTimeZone(absl::TimeZone tz);
|
||
|
|
||
|
// Returns the TimeZone used for human-friendly times (for example, the log
|
||
|
// message prefix) printed by the logging library Returns nullptr prior to
|
||
|
// initialization.
|
||
|
const absl::TimeZone* TimeZone();
|
||
|
|
||
|
// Returns true if stack traces emitted by the logging library should be
|
||
|
// symbolized. This function is async-signal-safe.
|
||
|
bool ShouldSymbolizeLogStackTrace();
|
||
|
|
||
|
// Enables or disables symbolization of stack traces emitted by the
|
||
|
// logging library. This function is async-signal-safe.
|
||
|
void EnableSymbolizeLogStackTrace(bool on_off);
|
||
|
|
||
|
// Returns the maximum number of frames that appear in stack traces
|
||
|
// emitted by the logging library. This function is async-signal-safe.
|
||
|
int MaxFramesInLogStackTrace();
|
||
|
|
||
|
// Sets the maximum number of frames that appear in stack traces emitted by
|
||
|
// the logging library. This function is async-signal-safe.
|
||
|
void SetMaxFramesInLogStackTrace(int max_num_frames);
|
||
|
|
||
|
// Determines whether we exit the program for a LOG(DFATAL) message in
|
||
|
// debug mode. It does this by skipping the call to Fail/FailQuietly.
|
||
|
// This is intended for testing only.
|
||
|
//
|
||
|
// This can have some effects on LOG(FATAL) as well. Failure messages
|
||
|
// are always allocated (rather than sharing a buffer), the crash
|
||
|
// reason is not recorded, the "gwq" status message is not updated,
|
||
|
// and the stack trace is not recorded. The LOG(FATAL) *will* still
|
||
|
// exit the program. Since this function is used only in testing,
|
||
|
// these differences are acceptable.
|
||
|
//
|
||
|
// Additionally, LOG(LEVEL(FATAL)) is indistinguishable from LOG(DFATAL) and
|
||
|
// will not terminate the program if SetExitOnDFatal(false) has been called.
|
||
|
bool ExitOnDFatal();
|
||
|
|
||
|
// SetExitOnDFatal() sets the ExitOnDFatal() status
|
||
|
void SetExitOnDFatal(bool on_off);
|
||
|
|
||
|
// Determines if the logging library should suppress logging of stacktraces in
|
||
|
// the `SIGABRT` handler, typically because we just logged a stacktrace as part
|
||
|
// of `LOG(FATAL)` and are about to send ourselves a `SIGABRT` to end the
|
||
|
// program.
|
||
|
bool SuppressSigabortTrace();
|
||
|
|
||
|
// Sets the SuppressSigabortTrace() status and returns the previous state.
|
||
|
bool SetSuppressSigabortTrace(bool on_off);
|
||
|
|
||
|
} // namespace log_internal
|
||
|
ABSL_NAMESPACE_END
|
||
|
} // namespace absl
|
||
|
|
||
|
#endif // ABSL_LOG_INTERNAL_GLOBALS_H_
|