You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
openmw-tes3coop/components/openmw-mp/Log.cpp

100 lines
1.9 KiB
C++

9 years ago
//
// Created by koncord on 15.08.16.
//
#include <cstdarg>
#include <iostream>
#include <cstring>
#include <ctime>
#include <cstdio>
#include <sstream>
#include <vector>
9 years ago
#include "Log.hpp"
using namespace std;
Log *Log::sLog = NULL;
9 years ago
Log::Log(int logLevel) : logLevel(logLevel)
{
}
void Log::Create(int logLevel)
{
if (sLog != NULL)
9 years ago
return;
sLog = new Log(logLevel);
}
void Log::Delete()
{
if (sLog == NULL)
9 years ago
return
delete sLog;
sLog = NULL;
9 years ago
}
const Log &Log::Get()
{
return *sLog;
}
void Log::SetLevel(int level)
{
sLog->logLevel = level;
}
9 years ago
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 + 1, tm->tm_mday,
9 years ago
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::stringstream sstr;
sstr << "[" << getTime() << "] ";
9 years ago
if (file != 0 && line != 0)
{
sstr << "[" << file << ":";
sstr << line << "] ";
}
9 years ago
sstr << "[";
switch (level)
9 years ago
{
case LOG_WARN:
sstr << "WARN";
9 years ago
break;
case LOG_ERROR:
sstr << "ERR";
9 years ago
break;
case LOG_FATAL:
sstr << "FATAL";
9 years ago
break;
default:
sstr << "INFO";
9 years ago
}
sstr << "]: ";
sstr << message;
char back = *sstr.str().rbegin();
if (back != '\n')
sstr << '\n';
9 years ago
va_list args;
va_start(args, message);
vector<char> buf(vsnprintf(NULL, 0, sstr.str().c_str(), args) + 1);
9 years ago
va_end(args);
va_start(args, message);
vsnprintf(buf.data(), buf.size(), sstr.str().c_str(), args);
va_end(args);
cout << buf.data() << flush;
9 years ago
}