Added simple log-file support. Use environment variable "LAMEXP_LOGFILE" to setup a log file.
This commit is contained in:
parent
db587fe228
commit
1bbda2c030
@ -30,7 +30,7 @@
|
|||||||
#define VER_LAMEXP_MINOR_LO 4
|
#define VER_LAMEXP_MINOR_LO 4
|
||||||
#define VER_LAMEXP_TYPE Alpha
|
#define VER_LAMEXP_TYPE Alpha
|
||||||
#define VER_LAMEXP_PATCH 12
|
#define VER_LAMEXP_PATCH 12
|
||||||
#define VER_LAMEXP_BUILD 853
|
#define VER_LAMEXP_BUILD 854
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// Tool versions (minimum expected versions!)
|
// Tool versions (minimum expected versions!)
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <intrin.h>
|
#include <intrin.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
//COM includes
|
//COM includes
|
||||||
#include <Objbase.h>
|
#include <Objbase.h>
|
||||||
@ -229,6 +230,9 @@ static const DWORD g_main_thread_id = GetCurrentThreadId();
|
|||||||
//Session ending flag
|
//Session ending flag
|
||||||
static bool g_sessionIsEnding = false;
|
static bool g_sessionIsEnding = false;
|
||||||
|
|
||||||
|
//Log file
|
||||||
|
static FILE *g_lamexp_log_file = NULL;
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// GLOBAL FUNCTIONS
|
// GLOBAL FUNCTIONS
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
@ -401,11 +405,14 @@ void lamexp_message_handler(QtMsgType type, const char *msg)
|
|||||||
|
|
||||||
QMutexLocker lock(&g_lamexp_message_mutex);
|
QMutexLocker lock(&g_lamexp_message_mutex);
|
||||||
|
|
||||||
//if((strlen(msg) > 8) && (_strnicmp(msg, "@BASE64@", 8) == 0))
|
if(g_lamexp_log_file)
|
||||||
//{
|
{
|
||||||
// buffer = _strdup(QByteArray::fromBase64(msg + 8).constData());
|
static char prefix[] = "DWCF";
|
||||||
// if(buffer) text = buffer;
|
int index = qBound(0, static_cast<int>(type), 3);
|
||||||
//}
|
QString str = QString::fromUtf8(msg).trimmed().replace('\n', '\t');
|
||||||
|
fprintf(g_lamexp_log_file, "[%c][%04I64d] %s\r\n", prefix[index], _time64(NULL) % 3600I64, str.toUtf8().constData());
|
||||||
|
fflush(g_lamexp_log_file);
|
||||||
|
}
|
||||||
|
|
||||||
if(g_lamexp_console_attached)
|
if(g_lamexp_console_attached)
|
||||||
{
|
{
|
||||||
@ -476,6 +483,22 @@ void lamexp_init_console(int argc, char* argv[])
|
|||||||
{
|
{
|
||||||
bool enableConsole = lamexp_version_demo();
|
bool enableConsole = lamexp_version_demo();
|
||||||
|
|
||||||
|
if(_environ)
|
||||||
|
{
|
||||||
|
wchar_t *logfile = NULL;
|
||||||
|
size_t logfile_len = 0;
|
||||||
|
if(!_wdupenv_s(&logfile, &logfile_len, L"LAMEXP_LOGFILE"))
|
||||||
|
{
|
||||||
|
FILE *temp = NULL;
|
||||||
|
if(!_wfopen_s(&temp, logfile, L"wb"))
|
||||||
|
{
|
||||||
|
fprintf(temp, "%c%c%c", 0xEF, 0xBB, 0xBF);
|
||||||
|
g_lamexp_log_file = temp;
|
||||||
|
}
|
||||||
|
free(logfile);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(!LAMEXP_DEBUG)
|
if(!LAMEXP_DEBUG)
|
||||||
{
|
{
|
||||||
for(int i = 0; i < argc; i++)
|
for(int i = 0; i < argc; i++)
|
||||||
@ -1875,6 +1898,13 @@ void lamexp_finalization(void)
|
|||||||
LAMEXP_DELETE(g_lamexp_ipc_ptr.sharedmem);
|
LAMEXP_DELETE(g_lamexp_ipc_ptr.sharedmem);
|
||||||
LAMEXP_DELETE(g_lamexp_ipc_ptr.semaphore_read);
|
LAMEXP_DELETE(g_lamexp_ipc_ptr.semaphore_read);
|
||||||
LAMEXP_DELETE(g_lamexp_ipc_ptr.semaphore_write);
|
LAMEXP_DELETE(g_lamexp_ipc_ptr.semaphore_write);
|
||||||
|
|
||||||
|
//Close log file
|
||||||
|
if(g_lamexp_log_file)
|
||||||
|
{
|
||||||
|
fclose(g_lamexp_log_file);
|
||||||
|
g_lamexp_log_file = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
x
Reference in New Issue
Block a user