File: fatal_logger.cpp

package info (click to toggle)
kddockwidgets 2.4.0%2Bds-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 11,412 kB
  • sloc: cpp: 50,019; ansic: 765; python: 239; xml: 61; makefile: 14; sh: 7
file content (57 lines) | stat: -rw-r--r-- 1,724 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/*
  This file is part of KDDockWidgets.

  SPDX-FileCopyrightText: 2023 Klarälvdalens Datakonsult AB, a KDAB Group company <info@kdab.com>
  Author: Sérgio Martins <sergio.martins@kdab.com>

  SPDX-License-Identifier: GPL-2.0-only OR GPL-3.0-only

  Contact KDAB at <info@kdab.com> for commercial licensing options.
*/

#include "fatal_logger.h"
#include "core/Logging_p.h"
#include "core/Platform.h"
#include "core/Utils_p.h"

using namespace KDDockWidgets;

FatalLogger::~FatalLogger() = default;

void FatalLogger::log(const spdlog::details::log_msg &msg)
{
    if (msg.level < spdlog::level::err) {
        // Nothing to do if less than err
        spdlog::sinks::stdout_color_sink_mt::log(msg);
        return;
    }

    const std::string expectedWarning = Core::Platform::instance()->m_expectedWarning;
    if (!expectedWarning.empty() && stringContains(std::string_view(msg.payload.data()), expectedWarning)) {
        // It's whitelisted, downgrade to warning level
        spdlog::details::log_msg copy = msg;
        copy.level = spdlog::level::warn;
        spdlog::sinks::stdout_color_sink_mt::log(copy);
        return;
    }


    spdlog::sinks::stdout_color_sink_mt::log(msg);

    spdlog::critical("KDDockWidgets should be error free. Aborting tests.");
    std::terminate();
}

std::shared_ptr<spdlog::logger> FatalLogger::create()
{
    if (spdlog::get(KDDockWidgets::spdlogLoggerName())) {
        // doesn't happen
        spdlog::critical("Tests bug, install the FatalLogger earlier.");
        std::terminate();
    }

    auto logger = std::make_shared<spdlog::logger>(KDDockWidgets::spdlogLoggerName(), std::make_shared<FatalLogger>());
    spdlog::register_logger(logger);

    return logger;
}