2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
|
|
|
|
2012-09-23 18:09:57 -04:00
|
|
|
#include "Log.h"
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
#include <fstream>
|
|
|
|
#include <ctime>
|
2012-09-23 17:23:33 -04:00
|
|
|
#include "OSSupport/IsThread.h"
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2012-08-15 17:24:11 -04:00
|
|
|
#if defined(ANDROID_NDK)
|
2012-09-23 17:23:33 -04:00
|
|
|
#include <android/log.h>
|
|
|
|
#include "ToJava.h"
|
2012-08-15 17:24:11 -04:00
|
|
|
#endif
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cLog* cLog::s_Log = NULL;
|
|
|
|
|
|
|
|
cLog::cLog(const AString & a_FileName )
|
|
|
|
: m_File(NULL)
|
|
|
|
{
|
|
|
|
s_Log = this;
|
|
|
|
|
|
|
|
// create logs directory
|
2013-10-09 03:57:48 -04:00
|
|
|
cFile::CreateFolder(FILE_IO_PREFIX + AString("logs"));
|
2012-06-14 09:06:06 -04:00
|
|
|
|
2013-10-09 03:57:48 -04:00
|
|
|
OpenLog((FILE_IO_PREFIX + AString("logs/") + a_FileName).c_str() );
|
2012-06-14 09:06:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cLog::~cLog()
|
|
|
|
{
|
|
|
|
CloseLog();
|
|
|
|
s_Log = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-02-27 09:17:42 -05:00
|
|
|
cLog * cLog::GetInstance()
|
2012-06-14 09:06:06 -04:00
|
|
|
{
|
2013-10-09 03:57:48 -04:00
|
|
|
if (s_Log != NULL)
|
|
|
|
{
|
2012-06-14 09:06:06 -04:00
|
|
|
return s_Log;
|
2013-10-09 03:57:48 -04:00
|
|
|
}
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
new cLog("log.txt");
|
|
|
|
return s_Log;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void cLog::CloseLog()
|
|
|
|
{
|
|
|
|
if( m_File )
|
|
|
|
fclose (m_File);
|
|
|
|
m_File = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void cLog::OpenLog( const char* a_FileName )
|
|
|
|
{
|
|
|
|
if(m_File) fclose (m_File);
|
2013-05-25 10:59:41 -04:00
|
|
|
#ifdef _MSC_VER
|
2012-06-14 09:06:06 -04:00
|
|
|
fopen_s( &m_File, a_FileName, "a+" );
|
|
|
|
#else
|
|
|
|
m_File = fopen(a_FileName, "a+" );
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void cLog::ClearLog()
|
|
|
|
{
|
2013-05-25 10:59:41 -04:00
|
|
|
#ifdef _MSC_VER
|
2012-06-14 09:06:06 -04:00
|
|
|
if( fopen_s( &m_File, "log.txt", "w" ) == 0)
|
|
|
|
fclose (m_File);
|
|
|
|
#else
|
|
|
|
m_File = fopen("log.txt", "w" );
|
|
|
|
if( m_File )
|
|
|
|
fclose (m_File);
|
|
|
|
#endif
|
2014-02-27 09:17:42 -05:00
|
|
|
m_File = NULL;
|
2012-06-14 09:06:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-01-16 02:34:10 -05:00
|
|
|
void cLog::Log(const char * a_Format, va_list argList)
|
2012-06-14 09:06:06 -04:00
|
|
|
{
|
|
|
|
AString Message;
|
2014-01-16 02:34:10 -05:00
|
|
|
AppendVPrintf(Message, a_Format, argList);
|
2012-06-14 09:06:06 -04:00
|
|
|
|
|
|
|
time_t rawtime;
|
|
|
|
time ( &rawtime );
|
|
|
|
|
|
|
|
struct tm* timeinfo;
|
2013-05-25 10:59:41 -04:00
|
|
|
#ifdef _MSC_VER
|
2012-06-14 09:06:06 -04:00
|
|
|
struct tm timeinforeal;
|
|
|
|
timeinfo = &timeinforeal;
|
|
|
|
localtime_s(timeinfo, &rawtime );
|
|
|
|
#else
|
|
|
|
timeinfo = localtime( &rawtime );
|
|
|
|
#endif
|
|
|
|
|
|
|
|
AString Line;
|
|
|
|
#ifdef _DEBUG
|
2014-03-14 09:11:49 -04:00
|
|
|
Printf(Line, "[%04lx|%02d:%02d:%02d] %s", cIsThread::GetCurrentID(), timeinfo->tm_hour, timeinfo->tm_min, timeinfo->tm_sec, Message.c_str());
|
2012-06-14 09:06:06 -04:00
|
|
|
#else
|
2013-08-10 07:03:05 -04:00
|
|
|
Printf(Line, "[%02d:%02d:%02d] %s", timeinfo->tm_hour, timeinfo->tm_min, timeinfo->tm_sec, Message.c_str());
|
2012-06-14 09:06:06 -04:00
|
|
|
#endif
|
|
|
|
if (m_File)
|
|
|
|
{
|
2013-11-13 15:09:24 -05:00
|
|
|
fprintf(m_File, "%s\n", Line.c_str());
|
2012-06-14 09:06:06 -04:00
|
|
|
fflush(m_File);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Print to console:
|
2012-08-16 16:28:14 -04:00
|
|
|
#if defined(ANDROID_NDK)
|
2014-07-17 13:13:23 -04:00
|
|
|
// __android_log_vprint(ANDROID_LOG_ERROR,"MCServer", a_Format, argList);
|
2012-08-18 19:42:27 -04:00
|
|
|
__android_log_print(ANDROID_LOG_ERROR, "MCServer", "%s", Line.c_str() );
|
2014-07-17 13:13:23 -04:00
|
|
|
// CallJavaFunction_Void_String(g_JavaThread, "AddToLog", Line );
|
2012-08-16 16:28:14 -04:00
|
|
|
#else
|
2012-06-14 09:06:06 -04:00
|
|
|
printf("%s", Line.c_str());
|
2012-08-16 16:28:14 -04:00
|
|
|
#endif
|
|
|
|
|
2012-06-14 09:06:06 -04:00
|
|
|
#if defined (_WIN32) && defined(_DEBUG)
|
|
|
|
// In a Windows Debug build, output the log to debug console as well:
|
2013-08-12 02:42:18 -04:00
|
|
|
OutputDebugStringA((Line + "\n").c_str());
|
2012-06-14 09:06:06 -04:00
|
|
|
#endif // _WIN32
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-01-15 12:28:51 -05:00
|
|
|
void cLog::Log(const char * a_Format, ...)
|
2012-06-14 09:06:06 -04:00
|
|
|
{
|
2014-01-16 02:34:10 -05:00
|
|
|
va_list argList;
|
2012-06-14 09:06:06 -04:00
|
|
|
va_start(argList, a_Format);
|
2014-01-16 02:34:10 -05:00
|
|
|
Log(a_Format, argList);
|
2012-06-14 09:06:06 -04:00
|
|
|
va_end(argList);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-01-15 12:28:51 -05:00
|
|
|
void cLog::SimpleLog(const char * a_String)
|
2012-06-14 09:06:06 -04:00
|
|
|
{
|
2014-01-15 12:28:51 -05:00
|
|
|
Log("%s", a_String);
|
2012-06-14 09:06:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|