From f5f56e1a1c4d9e9496fcb9d81131066a964ccd23 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 13 Apr 2024 14:15:43 +0200 Subject: Adding upstream version 2.4.1. Signed-off-by: Daniel Baumann --- src/lib/log/logger_name.cc | 58 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 src/lib/log/logger_name.cc (limited to 'src/lib/log/logger_name.cc') diff --git a/src/lib/log/logger_name.cc b/src/lib/log/logger_name.cc new file mode 100644 index 0000000..39a79cc --- /dev/null +++ b/src/lib/log/logger_name.cc @@ -0,0 +1,58 @@ +// Copyright (C) 2011-2015 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#include + +#include +#include + +namespace isc { +namespace log { + +namespace { + +// Obtain the root logger name in a way that is safe for statically-initialized +// objects. + +std::string& +getRootLoggerNameInternal() { + static std::string root_name; + return (root_name); +} + +} // Anonymous namespace + +void +setRootLoggerName(const std::string& name) { + getRootLoggerNameInternal() = name; +} + +const std::string& getRootLoggerName() { + return (getRootLoggerNameInternal()); +} + +const std::string& getDefaultRootLoggerName() { + static std::string root_name("kea"); + return (root_name); +} + +std::string expandLoggerName(const std::string& name) { + + // Are we the root logger, or does the logger name start with + // the string ".". If so, use a logger + // whose name is the one given. + if ((name == getRootLoggerName()) || + (name.find(getRootLoggerName() + std::string(".")) == 0)) { + return (name); + + } + + // Anything else is assumed to be a sub-logger of the root logger. + return (getRootLoggerName() + "." + name); +} + +} // namespace log +} // namespace isc -- cgit v1.2.3