Files
dolphin/Source/Core/Common/Logging/LogManager.h
T

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

85 lines
2.0 KiB
C++
Raw Normal View History

// Copyright 2009 Dolphin Emulator Project
2015-05-18 01:08:10 +02:00
// Licensed under GPLv2+
// Refer to the license.txt file included.
#pragma once
#include <array>
#include <cstdarg>
2020-07-24 13:58:46 -04:00
#include <map>
2017-07-07 15:23:47 -07:00
#include "Common/BitSet.h"
#include "Common/Logging/Log.h"
2014-02-17 05:18:15 -05:00
2019-11-28 04:19:24 -05:00
namespace Common::Log
{
// pure virtual interface
class LogListener
{
public:
2019-11-28 04:19:24 -05:00
virtual ~LogListener() = default;
virtual void Log(LOG_LEVELS level, const char* msg) = 0;
2016-01-21 20:46:25 +01:00
enum LISTENER
{
2016-01-21 20:46:25 +01:00
FILE_LISTENER = 0,
CONSOLE_LISTENER,
LOG_WINDOW_LISTENER,
NUMBER_OF_LISTENERS // Must be last
};
};
2017-08-04 23:57:12 +02:00
class LogManager
{
public:
2017-07-07 15:00:25 -07:00
static LogManager* GetInstance();
static void Init();
static void Shutdown();
2019-11-28 04:19:24 -05:00
void Log(LOG_LEVELS level, LOG_TYPE type, const char* file, int line, const char* fmt,
va_list args);
void LogWithFullPath(LOG_LEVELS level, LOG_TYPE type, const char* file, int line, const char* fmt,
va_list args);
2019-11-28 04:19:24 -05:00
LOG_LEVELS GetLogLevel() const;
void SetLogLevel(LOG_LEVELS level);
2019-11-28 04:19:24 -05:00
void SetEnable(LOG_TYPE type, bool enable);
bool IsEnabled(LOG_TYPE type, LOG_LEVELS level = LNOTICE) const;
2020-07-24 13:58:46 -04:00
std::map<std::string, std::string> GetLogTypes();
2019-11-28 04:19:24 -05:00
const char* GetShortName(LOG_TYPE type) const;
const char* GetFullName(LOG_TYPE 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;
2017-07-07 16:10:38 -07:00
void SaveSettings();
2017-07-07 15:00:25 -07:00
private:
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();
2017-08-04 23:57:12 +02:00
LogManager(const LogManager&) = delete;
LogManager& operator=(const LogManager&) = delete;
LogManager(LogManager&&) = delete;
LogManager& operator=(LogManager&&) = delete;
2019-11-28 04:19:24 -05:00
LOG_LEVELS m_level;
std::array<LogContainer, NUMBER_OF_LOGS> 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;
};
2019-11-28 04:19:24 -05:00
} // namespace Common::Log