2015-05-24 07:55:12 +03:00
|
|
|
// Copyright 2009 Dolphin Emulator Project
|
2015-05-18 02:08:10 +03:00
|
|
|
// Licensed under GPLv2+
|
2013-04-18 06:09:55 +03:00
|
|
|
// Refer to the license.txt file included.
|
2009-03-18 19:17:58 +02:00
|
|
|
|
2014-02-10 20:54:46 +02:00
|
|
|
#pragma once
|
2009-03-18 19:17:58 +02:00
|
|
|
|
2015-10-03 14:34:36 +03:00
|
|
|
#include <array>
|
2014-02-20 05:11:52 +02:00
|
|
|
#include <cstdarg>
|
2014-06-06 01:24:10 +03:00
|
|
|
#include <string>
|
2009-03-18 19:17:58 +02:00
|
|
|
|
2015-09-27 00:13:07 +03:00
|
|
|
#include "Common/Logging/Log.h"
|
2016-06-24 11:43:46 +03:00
|
|
|
#include "Common/NonCopyable.h"
|
2014-02-17 12:18:15 +02:00
|
|
|
|
2011-04-01 10:43:02 +03:00
|
|
|
// pure virtual interface
|
|
|
|
class LogListener
|
|
|
|
{
|
2009-03-18 19:17:58 +02:00
|
|
|
public:
|
2016-06-24 11:43:46 +03:00
|
|
|
virtual ~LogListener() {}
|
|
|
|
virtual void Log(LogTypes::LOG_LEVELS, const char* msg) = 0;
|
2011-04-01 10:43:02 +03:00
|
|
|
|
2016-06-24 11:43:46 +03:00
|
|
|
enum LISTENER
|
|
|
|
{
|
|
|
|
FILE_LISTENER = 0,
|
|
|
|
CONSOLE_LISTENER,
|
|
|
|
LOG_WINDOW_LISTENER,
|
2015-10-03 14:34:36 +03:00
|
|
|
|
2016-06-24 11:43:46 +03:00
|
|
|
NUMBER_OF_LISTENERS // Must be last
|
|
|
|
};
|
2009-03-18 19:17:58 +02:00
|
|
|
};
|
|
|
|
|
2017-07-08 01:00:25 +03:00
|
|
|
class LogContainer;
|
2014-02-23 08:33:03 +02:00
|
|
|
|
2010-11-15 07:29:10 +02:00
|
|
|
class LogManager : NonCopyable
|
2009-03-18 19:17:58 +02:00
|
|
|
{
|
2016-06-24 11:43:46 +03:00
|
|
|
public:
|
2017-07-08 01:00:25 +03:00
|
|
|
static LogManager* GetInstance();
|
|
|
|
static void Init();
|
|
|
|
static void Shutdown();
|
|
|
|
|
2016-06-24 11:43:46 +03:00
|
|
|
void Log(LogTypes::LOG_LEVELS level, LogTypes::LOG_TYPE type, const char* file, int line,
|
|
|
|
const char* fmt, va_list args);
|
2017-04-24 09:55:37 +03:00
|
|
|
void LogWithFullPath(LogTypes::LOG_LEVELS level, LogTypes::LOG_TYPE type, const char* file,
|
|
|
|
int line, const char* fmt, va_list args);
|
2016-06-24 11:43:46 +03:00
|
|
|
|
2017-07-08 01:00:25 +03:00
|
|
|
void SetLogLevel(LogTypes::LOG_TYPE type, LogTypes::LOG_LEVELS level);
|
2016-06-24 11:43:46 +03:00
|
|
|
|
2017-07-08 01:00:25 +03:00
|
|
|
void SetEnable(LogTypes::LOG_TYPE type, bool enable);
|
|
|
|
bool IsEnabled(LogTypes::LOG_TYPE type, LogTypes::LOG_LEVELS level = LogTypes::LNOTICE) const;
|
2016-06-24 11:43:46 +03:00
|
|
|
|
2017-07-08 01:00:25 +03:00
|
|
|
std::string GetShortName(LogTypes::LOG_TYPE type) const;
|
|
|
|
std::string GetFullName(LogTypes::LOG_TYPE type) const;
|
|
|
|
void RegisterListener(LogListener::LISTENER id, LogListener* listener);
|
|
|
|
void AddListener(LogTypes::LOG_TYPE type, LogListener::LISTENER id);
|
|
|
|
void RemoveListener(LogTypes::LOG_TYPE type, LogListener::LISTENER id);
|
2016-06-24 11:43:46 +03:00
|
|
|
|
2017-07-08 01:00:25 +03:00
|
|
|
private:
|
|
|
|
LogManager();
|
|
|
|
~LogManager();
|
2016-06-24 11:43:46 +03:00
|
|
|
|
2017-07-08 01:00:25 +03:00
|
|
|
LogContainer* m_log[LogTypes::NUMBER_OF_LOGS];
|
|
|
|
std::array<LogListener*, LogListener::NUMBER_OF_LISTENERS> m_listeners{};
|
|
|
|
size_t m_path_cutoff_point = 0;
|
2009-03-18 19:17:58 +02:00
|
|
|
};
|