57952505e5
* Update fmt to 6.2.0
96 lines
2.0 KiB
C++
96 lines
2.0 KiB
C++
|
|
#pragma once
|
|
|
|
|
|
class cLogger
|
|
{
|
|
public:
|
|
|
|
enum eLogLevel
|
|
{
|
|
llRegular,
|
|
llInfo,
|
|
llWarning,
|
|
llError,
|
|
};
|
|
|
|
|
|
class cListener
|
|
{
|
|
public:
|
|
virtual void Log(AString a_Message, eLogLevel a_LogLevel) = 0;
|
|
|
|
virtual ~cListener(){}
|
|
};
|
|
|
|
class cAttachment
|
|
{
|
|
public:
|
|
|
|
cAttachment() : m_listener(nullptr) {}
|
|
cAttachment(cAttachment && a_other)
|
|
: m_listener(a_other.m_listener)
|
|
{
|
|
a_other.m_listener = nullptr;
|
|
}
|
|
|
|
~cAttachment()
|
|
{
|
|
if (m_listener != nullptr)
|
|
{
|
|
cLogger::GetInstance().DetachListener(m_listener);
|
|
}
|
|
}
|
|
|
|
cAttachment & operator=(cAttachment && a_other)
|
|
{
|
|
m_listener = a_other.m_listener;
|
|
a_other.m_listener = nullptr;
|
|
return *this;
|
|
}
|
|
|
|
private:
|
|
|
|
cListener * m_listener;
|
|
|
|
friend class cLogger;
|
|
|
|
cAttachment(cListener * a_listener) : m_listener(a_listener) {}
|
|
};
|
|
|
|
/** Log a message formatted with a printf style formatting string. */
|
|
void vLogPrintf(const char * a_Format, eLogLevel a_LogLevel, fmt::printf_args a_ArgList);
|
|
template <typename... Args>
|
|
void LogPrintf(const char * a_Format, eLogLevel a_LogLevel, const Args & ... args)
|
|
{
|
|
vLogPrintf(a_Format, a_LogLevel, fmt::make_printf_args(args...));
|
|
}
|
|
|
|
/** Log a message formatted with a python style formatting string. */
|
|
void vLogFormat(const char * a_Format, eLogLevel a_LogLevel, fmt::format_args a_ArgList);
|
|
template <typename... Args>
|
|
void LogFormat(const char * a_Format, eLogLevel a_LogLevel, const Args & ... args)
|
|
{
|
|
vLogFormat(a_Format, a_LogLevel, fmt::make_format_args(args...));
|
|
}
|
|
|
|
/** Logs the simple text message at the specified log level. */
|
|
void LogSimple(AString a_Message, eLogLevel a_LogLevel = llRegular);
|
|
|
|
cAttachment AttachListener(std::unique_ptr<cListener> a_Listener);
|
|
|
|
static cLogger & GetInstance(void);
|
|
// Must be called before calling GetInstance in a multithreaded context
|
|
static void InitiateMultithreading();
|
|
private:
|
|
|
|
cCriticalSection m_CriticalSection;
|
|
std::vector<std::unique_ptr<cListener>> m_LogListeners;
|
|
|
|
void DetachListener(cListener * a_Listener);
|
|
|
|
};
|
|
|
|
|
|
|