198 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
 | 
						|
#include "Globals.h"  // NOTE: MSVC stupidness requires this to be the same across all modules
 | 
						|
 | 
						|
#include <time.h>
 | 
						|
#include "Log.h"
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
cMCLogger * cMCLogger::s_MCLogger = NULL;
 | 
						|
 | 
						|
#ifdef _WIN32
 | 
						|
	HANDLE g_Console = GetStdHandle(STD_OUTPUT_HANDLE);
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
cMCLogger* cMCLogger::GetInstance()
 | 
						|
{
 | 
						|
	return s_MCLogger;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
cMCLogger::cMCLogger(void)
 | 
						|
{
 | 
						|
	AString FileName;
 | 
						|
	Printf(FileName, "LOG_%d.txt", (int)time(NULL));
 | 
						|
	m_Log = new cLog(FileName);
 | 
						|
	m_Log->Log("--- Started Log ---");
 | 
						|
 | 
						|
	s_MCLogger = this;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
cMCLogger::cMCLogger(const AString & a_FileName)
 | 
						|
{
 | 
						|
	m_Log = new cLog(a_FileName);
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
cMCLogger::~cMCLogger()
 | 
						|
{
 | 
						|
	m_Log->Log("--- Stopped Log ---");
 | 
						|
	delete m_Log;
 | 
						|
	if (this == s_MCLogger)
 | 
						|
		s_MCLogger = NULL;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
void cMCLogger::LogSimple(const char* a_Text, int a_LogType /* = 0 */ )
 | 
						|
{
 | 
						|
	switch( a_LogType )
 | 
						|
	{
 | 
						|
		case 0:
 | 
						|
			LOG("%s", a_Text);
 | 
						|
			break;
 | 
						|
		case 1:
 | 
						|
			LOGINFO("%s", a_Text);
 | 
						|
			break;
 | 
						|
		case 2:
 | 
						|
			LOGWARN("%s", a_Text);
 | 
						|
			break;
 | 
						|
		case 3:
 | 
						|
			LOGERROR("%s", a_Text);
 | 
						|
			break;
 | 
						|
		default:
 | 
						|
			LOG("(#%d#: %s", a_LogType, a_Text);
 | 
						|
			break;
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
void cMCLogger::Log(const char* a_Format, va_list a_ArgList)
 | 
						|
{
 | 
						|
	cCSLock Lock(m_CriticalSection);
 | 
						|
	SetColor( 0x7 );	 // 0x7 is default grey color
 | 
						|
	m_Log->Log( a_Format, a_ArgList );
 | 
						|
	SetColor(0x07);  // revert color back
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
void cMCLogger::Info(const char* a_Format, va_list a_ArgList)
 | 
						|
{
 | 
						|
	cCSLock Lock(m_CriticalSection);
 | 
						|
// 	for( int i = 0; i < 16; i++)
 | 
						|
// 	{
 | 
						|
// 		for( int j = 0; j < 16; j++ )
 | 
						|
// 		{
 | 
						|
// 			SetConsoleTextAttribute( hConsole, i | (j<<4) );
 | 
						|
// 			printf("0x%x", (i|j<<4));
 | 
						|
// 		}
 | 
						|
// 		printf("\n");
 | 
						|
// 	}
 | 
						|
 | 
						|
	SetColor( 0xe );	 // 0xe is yellow
 | 
						|
	m_Log->Log( a_Format, a_ArgList );
 | 
						|
	SetColor(0x07);  // revert color back
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
void cMCLogger::Warn(const char* a_Format, va_list a_ArgList)
 | 
						|
{
 | 
						|
	cCSLock Lock(m_CriticalSection);
 | 
						|
	SetColor( 0xc );	 // 0xc is red
 | 
						|
	m_Log->Log( a_Format, a_ArgList );
 | 
						|
	SetColor(0x07);  // revert color back
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
void cMCLogger::Error(const char* a_Format, va_list a_ArgList)
 | 
						|
{
 | 
						|
	cCSLock Lock(m_CriticalSection);
 | 
						|
	SetColor( 0xc0 );	// 0xc0 is red bg and black text
 | 
						|
	m_Log->Log( a_Format, a_ArgList );
 | 
						|
	SetColor(0x07);  // revert color back
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
void cMCLogger::SetColor( unsigned char a_Color )
 | 
						|
{
 | 
						|
#ifdef _WIN32
 | 
						|
	SetConsoleTextAttribute(g_Console, a_Color);
 | 
						|
#else
 | 
						|
	(void)a_Color;
 | 
						|
#endif
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
//////////////////////////////////////////////////////////////////////////
 | 
						|
// Global functions
 | 
						|
void LOG(const char* a_Format, ...)
 | 
						|
{
 | 
						|
	va_list argList;
 | 
						|
	va_start(argList, a_Format);
 | 
						|
	cMCLogger::GetInstance()->Log( a_Format, argList );
 | 
						|
	va_end(argList);
 | 
						|
}
 | 
						|
 | 
						|
void LOGINFO(const char* a_Format, ...)
 | 
						|
{
 | 
						|
	va_list argList;
 | 
						|
	va_start(argList, a_Format);
 | 
						|
	cMCLogger::GetInstance()->Info( a_Format, argList );
 | 
						|
	va_end(argList);
 | 
						|
}
 | 
						|
 | 
						|
void LOGWARN(const char* a_Format, ...)
 | 
						|
{
 | 
						|
	va_list argList;
 | 
						|
	va_start(argList, a_Format);
 | 
						|
	cMCLogger::GetInstance()->Warn( a_Format, argList );
 | 
						|
	va_end(argList);
 | 
						|
}
 | 
						|
 | 
						|
void LOGERROR(const char* a_Format, ...)
 | 
						|
{
 | 
						|
	va_list argList;
 | 
						|
	va_start(argList, a_Format);
 | 
						|
	cMCLogger::GetInstance()->Error( a_Format, argList );
 | 
						|
	va_end(argList);
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 |