openmw-tes3coop/apps/openmw-mp/Log.cpp

82 lines
1.5 KiB
C++
Raw Normal View History

2016-08-14 23:45:42 +00:00
//
// Created by koncord on 15.08.16.
//
#include <cstdarg>
#include <iostream>
#include <cstring>
#include "Log.hpp"
using namespace std;
Log *Log::sLog = nullptr;
Log::Log(int logLevel) : logLevel(logLevel)
{
}
void Log::Create(int logLevel)
{
if(sLog != nullptr)
return;
sLog = new Log(logLevel);
}
void Log::Delete()
{
if(sLog == nullptr)
return
delete sLog;
sLog = nullptr;
}
const Log &Log::Get()
{
return *sLog;
}
const char* getTime()
{
time_t t = time(0);
struct tm *tm = localtime(&t);
static char result[20];
sprintf(result, "%.4d-%.2d-%.2d %.2d:%.2d:%.2d",
1900 + tm->tm_year, tm->tm_mon, tm->tm_mday,
tm->tm_hour, tm->tm_min, tm->tm_sec);
return result;
}
void Log::print(int level, const char *file, int line, const char *message, ...) const
{
if(level > logLevel) return;
std::string str = "[" + string(getTime()) + "] ";
if(file != 0 && line != 0)
str += "["+ string(file) + ":" + to_string(line) + "] ";
str += "[";
switch(level)
{
2016-08-15 13:33:18 +00:00
case LOG_WARN:
2016-08-14 23:45:42 +00:00
str += "WARN";
break;
2016-08-15 13:33:18 +00:00
case LOG_ERROR:
2016-08-14 23:45:42 +00:00
str += "ERR";
break;
2016-08-15 13:33:18 +00:00
case LOG_FATAL:
2016-08-14 23:45:42 +00:00
str += "FATAL";
break;
default:
str += "INFO";
}
str += "]: ";
str += message;
if(str.back() != '\n')
str += '\n';
va_list args;
va_start(args, message);
vprintf(str.c_str(), args);
va_end(args);
}