2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class cLog;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-01-11 23:46:01 -05:00
|
|
|
class cMCLogger // tolua_export
|
|
|
|
{ // tolua_export
|
|
|
|
public: // tolua_export
|
2013-10-12 05:26:42 -04:00
|
|
|
/// Creates a logger with the default filename, "logs/LOG_<timestamp>.log"
|
2013-02-03 15:37:13 -05:00
|
|
|
cMCLogger(void);
|
2013-10-12 05:26:42 -04:00
|
|
|
|
|
|
|
/// Creates a logger with the specified filename inside "logs" folder
|
2013-02-03 15:37:13 -05:00
|
|
|
cMCLogger(const AString & a_FileName); // tolua_export
|
2013-10-12 05:26:42 -04:00
|
|
|
|
2013-01-11 23:46:01 -05:00
|
|
|
~cMCLogger(); // tolua_export
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2014-01-29 14:22:03 -05:00
|
|
|
void Log(const char* a_Format, va_list a_ArgList, bool a_ShouldReplaceLine = false);
|
2012-06-14 09:06:06 -04:00
|
|
|
void Info(const char* a_Format, va_list a_ArgList);
|
|
|
|
void Warn(const char* a_Format, va_list a_ArgList);
|
|
|
|
void Error(const char* a_Format, va_list a_ArgList);
|
|
|
|
|
2013-01-11 23:46:01 -05:00
|
|
|
void LogSimple(const char* a_Text, int a_LogType = 0 ); // tolua_export
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
static cMCLogger* GetInstance();
|
|
|
|
private:
|
2013-08-09 16:40:12 -04:00
|
|
|
enum eColorScheme
|
|
|
|
{
|
2013-08-10 06:44:39 -04:00
|
|
|
csRegular,
|
|
|
|
csInfo,
|
|
|
|
csWarning,
|
|
|
|
csError,
|
2013-08-09 16:40:12 -04:00
|
|
|
} ;
|
|
|
|
|
2013-10-12 05:26:42 -04:00
|
|
|
cCriticalSection m_CriticalSection;
|
|
|
|
cLog * m_Log;
|
|
|
|
static cMCLogger * s_MCLogger;
|
|
|
|
|
|
|
|
|
2013-08-09 16:40:12 -04:00
|
|
|
/// Sets the specified color scheme in the terminal (TODO: if coloring available)
|
|
|
|
void SetColor(eColorScheme a_Scheme);
|
|
|
|
|
2013-08-10 06:44:39 -04:00
|
|
|
/// Resets the color back to whatever is the default in the terminal
|
|
|
|
void ResetColor(void);
|
|
|
|
|
2013-10-12 05:26:42 -04:00
|
|
|
/// Common initialization for all constructors, creates a logfile with the specified name and assigns s_MCLogger to this
|
|
|
|
void InitLog(const AString & a_FileName);
|
2014-01-31 15:50:29 -05:00
|
|
|
|
|
|
|
/** Flag to show whether a 'replace line' log command has been issued
|
|
|
|
Used to decide when to put a newline */
|
|
|
|
bool m_BeginLineUpdate;
|
2013-01-11 23:46:01 -05:00
|
|
|
}; // tolua_export
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2013-10-12 05:26:42 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-01-29 14:22:03 -05:00
|
|
|
extern void LOGREPLACELINE(const char* a_Format, ...);
|
2012-06-14 09:06:06 -04:00
|
|
|
extern void LOG(const char* a_Format, ...);
|
|
|
|
extern void LOGINFO(const char* a_Format, ...);
|
|
|
|
extern void LOGWARN(const char* a_Format, ...);
|
|
|
|
extern void LOGERROR(const char* a_Format, ...);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// In debug builds, translate LOGD to LOG, otherwise leave it out altogether:
|
|
|
|
#ifdef _DEBUG
|
|
|
|
#define LOGD LOG
|
|
|
|
#else
|
|
|
|
#define LOGD(...)
|
|
|
|
#endif // _DEBUG
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define LOGWARNING LOGWARN
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|