2015-05-24 06:55:12 +02:00
|
|
|
// Copyright 2009 Dolphin Emulator Project
|
2021-07-05 03:22:19 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2014-02-10 13:54:46 -05:00
|
|
|
#pragma once
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2015-10-04 00:34:36 +13:00
|
|
|
#include <array>
|
2014-02-20 04:11:52 +01:00
|
|
|
#include <cstdarg>
|
2020-07-24 13:58:46 -04:00
|
|
|
#include <map>
|
2020-08-02 19:52:10 -04:00
|
|
|
#include <string>
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2017-07-07 15:23:47 -07:00
|
|
|
#include "Common/BitSet.h"
|
2021-10-21 12:11:07 -07:00
|
|
|
#include "Common/EnumMap.h"
|
2015-09-26 17:13:07 -04:00
|
|
|
#include "Common/Logging/Log.h"
|
2014-02-17 05:18:15 -05:00
|
|
|
|
2019-11-28 04:19:24 -05:00
|
|
|
namespace Common::Log
|
|
|
|
|
{
|
2011-04-01 07:43:02 +00:00
|
|
|
// pure virtual interface
|
|
|
|
|
class LogListener
|
|
|
|
|
{
|
2009-03-18 17:17:58 +00:00
|
|
|
public:
|
2019-11-28 04:19:24 -05:00
|
|
|
virtual ~LogListener() = default;
|
2021-10-21 12:11:07 -07:00
|
|
|
virtual void Log(LogLevel level, const char* msg) = 0;
|
2011-04-01 07:43:02 +00:00
|
|
|
|
2016-01-21 20:46:25 +01:00
|
|
|
enum LISTENER
|
2016-06-24 10:43:46 +02:00
|
|
|
{
|
2016-01-21 20:46:25 +01:00
|
|
|
FILE_LISTENER = 0,
|
|
|
|
|
CONSOLE_LISTENER,
|
|
|
|
|
LOG_WINDOW_LISTENER,
|
2015-10-04 00:34:36 +13:00
|
|
|
|
|
|
|
|
NUMBER_OF_LISTENERS // Must be last
|
|
|
|
|
};
|
2009-03-18 17:17:58 +00:00
|
|
|
};
|
|
|
|
|
|
2017-08-04 23:57:12 +02:00
|
|
|
class LogManager
|
2009-03-18 17:17:58 +00:00
|
|
|
{
|
2010-02-19 18:50:01 +00:00
|
|
|
public:
|
2017-07-07 15:00:25 -07:00
|
|
|
static LogManager* GetInstance();
|
|
|
|
|
static void Init();
|
|
|
|
|
static void Shutdown();
|
|
|
|
|
|
2021-10-21 12:11:07 -07:00
|
|
|
void Log(LogLevel level, LogType type, const char* file, int line, const char* message);
|
2022-07-17 19:12:04 -07:00
|
|
|
void LogWithFullPath(LogLevel level, LogType type, const char* file, int line,
|
|
|
|
|
const char* message);
|
2010-01-19 19:28:27 +00:00
|
|
|
|
2021-10-21 12:11:07 -07:00
|
|
|
LogLevel GetLogLevel() const;
|
|
|
|
|
void SetLogLevel(LogLevel level);
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2021-10-21 12:11:07 -07:00
|
|
|
void SetEnable(LogType type, bool enable);
|
|
|
|
|
bool IsEnabled(LogType type, LogLevel level = LogLevel::LNOTICE) const;
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2020-07-24 13:58:46 -04:00
|
|
|
std::map<std::string, std::string> GetLogTypes();
|
|
|
|
|
|
2021-10-21 12:11:07 -07:00
|
|
|
const char* GetShortName(LogType type) const;
|
|
|
|
|
const char* GetFullName(LogType type) const;
|
2017-07-07 15:23:47 -07:00
|
|
|
|
2017-07-07 15:00:25 -07:00
|
|
|
void RegisterListener(LogListener::LISTENER id, LogListener* listener);
|
2017-07-07 15:23:47 -07:00
|
|
|
void EnableListener(LogListener::LISTENER id, bool enable);
|
|
|
|
|
bool IsListenerEnabled(LogListener::LISTENER id) const;
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2017-07-07 16:10:38 -07:00
|
|
|
void SaveSettings();
|
|
|
|
|
|
2017-07-07 15:00:25 -07:00
|
|
|
private:
|
2017-07-07 15:40:19 -07:00
|
|
|
struct LogContainer
|
|
|
|
|
{
|
|
|
|
|
const char* m_short_name;
|
|
|
|
|
const char* m_full_name;
|
|
|
|
|
bool m_enable = false;
|
|
|
|
|
};
|
|
|
|
|
|
2017-07-07 15:00:25 -07:00
|
|
|
LogManager();
|
|
|
|
|
~LogManager();
|
2009-03-18 17:17:58 +00:00
|
|
|
|
2017-08-04 23:57:12 +02:00
|
|
|
LogManager(const LogManager&) = delete;
|
|
|
|
|
LogManager& operator=(const LogManager&) = delete;
|
|
|
|
|
LogManager(LogManager&&) = delete;
|
|
|
|
|
LogManager& operator=(LogManager&&) = delete;
|
|
|
|
|
|
2022-07-17 19:46:34 -07:00
|
|
|
static std::string GetTimestamp();
|
|
|
|
|
|
2021-10-21 12:11:07 -07:00
|
|
|
LogLevel m_level;
|
2022-07-26 16:29:51 -05:00
|
|
|
EnumMap<LogContainer, LAST_LOG_TYPE> m_log{};
|
2017-07-07 15:00:25 -07:00
|
|
|
std::array<LogListener*, LogListener::NUMBER_OF_LISTENERS> m_listeners{};
|
2017-07-07 15:23:47 -07:00
|
|
|
BitSet32 m_listener_ids;
|
2017-07-07 15:00:25 -07:00
|
|
|
size_t m_path_cutoff_point = 0;
|
2009-03-18 17:17:58 +00:00
|
|
|
};
|
2019-11-28 04:19:24 -05:00
|
|
|
} // namespace Common::Log
|