From 19dc99f133edb6289e70fa8d719c6448e14533d3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?V=C3=A1clav=20Kubern=C3=A1t?= Date: Tue, 25 Jun 2024 14:47:20 +0200 Subject: [PATCH] Move messageHandler out of globalOptions globalOptions get overwritten every time you call setCLIOptions. This patch prevents overwriting messageHandler. --- libnecrolog/necrolog.cpp | 11 +++++++---- libnecrolog/necrolog.h | 1 - 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/libnecrolog/necrolog.cpp b/libnecrolog/necrolog.cpp index 55e9006..23ba350 100644 --- a/libnecrolog/necrolog.cpp +++ b/libnecrolog/necrolog.cpp @@ -12,6 +12,10 @@ #include #endif +namespace { +NecroLog::MessageHandler messageHandler = NecroLog::defaultMessageHandler; // NOLINT(cppcoreguidelines-avoid-non-const-global-variables) +} + NecroLog::Options &NecroLog::globalOptions() { static Options global_options; @@ -101,7 +105,7 @@ bool NecroLog::shouldLog(Level level, const LogContext &context) NecroLog::MessageHandler NecroLog::setMessageHandler(NecroLog::MessageHandler h) { - return std::exchange(globalOptions().messageHandler, h); + return std::exchange(messageHandler, h); } namespace { @@ -327,9 +331,8 @@ NecroLog::NecroLogSharedData::NecroLogSharedData(NecroLog::Level level, const Ne NecroLog::NecroLogSharedData::~NecroLogSharedData() { - auto h = globalOptions().messageHandler; - if(h) - h(m_level, m_logContext, m_os.str()); + if(messageHandler) + messageHandler(m_level, m_logContext, m_os.str()); } int NecroLog::moduleNameStart(const char *file_name) diff --git a/libnecrolog/necrolog.h b/libnecrolog/necrolog.h index 312a770..e912cd5 100644 --- a/libnecrolog/necrolog.h +++ b/libnecrolog/necrolog.h @@ -92,7 +92,6 @@ class NECROLOG_DECL_EXPORT NecroLog bool logLongFileNames = false; bool caseInsensitiveTopicMatch = false; ColorizedOutputMode colorizedOutput = ColorizedOutputMode::IfTty; - MessageHandler messageHandler = defaultMessageHandler; }; static Options& globalOptions();