mirror of
https://github.com/DarkflameUniverse/DarkflameServer
synced 2024-08-30 18:43:58 +00:00
144 lines
3.0 KiB
C++
144 lines
3.0 KiB
C++
|
#include "dLogger.h"
|
||
|
|
||
|
dLogger::dLogger(const std::string& outpath, bool logToConsole) {
|
||
|
m_logToConsole = logToConsole;
|
||
|
m_outpath = outpath;
|
||
|
|
||
|
#ifdef _WIN32
|
||
|
mFile = std::ofstream(m_outpath);
|
||
|
if (!mFile) { printf("Couldn't open %s for writing!\n", outpath.c_str()); }
|
||
|
#else
|
||
|
fp = fopen(outpath.c_str(), "wt");
|
||
|
if (fp == NULL) { printf("Couldn't open %s for writing!\n", outpath.c_str()); }
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
dLogger::~dLogger() {
|
||
|
#ifdef _WIN32
|
||
|
mFile.close();
|
||
|
#else
|
||
|
if (fp != nullptr) {
|
||
|
fclose(fp);
|
||
|
fp = nullptr;
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
void dLogger::LogBasic(const std::string & message) {
|
||
|
LogBasic(message.c_str());
|
||
|
}
|
||
|
|
||
|
void dLogger::LogBasic(const char * format, ...) {
|
||
|
#ifdef _WIN32
|
||
|
time_t t = time(NULL);
|
||
|
struct tm time;
|
||
|
localtime_s(&time, &t);
|
||
|
|
||
|
char timeStr[70];
|
||
|
|
||
|
strftime(timeStr, sizeof(timeStr), "%d-%m-%y %H:%M:%S", &time);
|
||
|
|
||
|
char message[2048];
|
||
|
va_list args;
|
||
|
va_start(args, format);
|
||
|
vsprintf_s(message, format, args);
|
||
|
va_end(args);
|
||
|
|
||
|
if (m_logToConsole) std::cout << "[" << "time machine broke" << "] " << message;
|
||
|
mFile << "[" << "time" << "] " << message;
|
||
|
#else
|
||
|
time_t t = time(NULL);
|
||
|
struct tm * time = localtime(&t);
|
||
|
char timeStr[70];
|
||
|
strftime(timeStr, sizeof(timeStr), "%d-%m-%y %H:%M:%S", time);
|
||
|
|
||
|
char message[2048];
|
||
|
va_list args;
|
||
|
va_start(args, format);
|
||
|
vsprintf(message, format, args);
|
||
|
va_end(args);
|
||
|
|
||
|
if (m_logToConsole) {
|
||
|
fputs("[", stdout);
|
||
|
fputs(timeStr, stdout);
|
||
|
fputs("] ", stdout);
|
||
|
fputs(message, stdout);
|
||
|
}
|
||
|
|
||
|
if (fp != nullptr) {
|
||
|
fputs("[", fp);
|
||
|
fputs(timeStr, fp);
|
||
|
fputs("] ", fp);
|
||
|
fputs(message, fp);
|
||
|
} else {
|
||
|
printf("Logger not initialized!\n");
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
void dLogger::Log(const char * className, const char * format, ...) {
|
||
|
#ifdef _WIN32
|
||
|
time_t t = time(NULL);
|
||
|
struct tm time;
|
||
|
localtime_s(&time, &t);
|
||
|
|
||
|
char timeStr[70];
|
||
|
strftime(timeStr, sizeof(timeStr), "%d-%m-%y %H:%M:%S", &time);
|
||
|
|
||
|
char message[2048];
|
||
|
va_list args;
|
||
|
va_start(args, format);
|
||
|
vsprintf_s(message, format, args);
|
||
|
|
||
|
va_end(args);
|
||
|
|
||
|
if (m_logToConsole) std::cout << "[" << "timeStr" << "] [" << className << "]: " << message;
|
||
|
mFile << "[" << "timeStr" << "] [" << className << "]: " << message;
|
||
|
#else
|
||
|
time_t t = time(NULL);
|
||
|
struct tm * time = localtime(&t);
|
||
|
char timeStr[70];
|
||
|
strftime(timeStr, sizeof(timeStr), "%d-%m-%y %H:%M:%S", time);
|
||
|
|
||
|
char message[2048];
|
||
|
va_list args;
|
||
|
va_start(args, format);
|
||
|
vsprintf(message, format, args);
|
||
|
va_end(args);
|
||
|
|
||
|
if (m_logToConsole) {
|
||
|
fputs("[", stdout);
|
||
|
fputs(timeStr, stdout);
|
||
|
fputs("] ", stdout);
|
||
|
fputs("[", stdout);
|
||
|
fputs(className, stdout);
|
||
|
fputs("]: ", stdout);
|
||
|
fputs(message, stdout);
|
||
|
}
|
||
|
|
||
|
if (fp != NULL) {
|
||
|
fputs("[", fp);
|
||
|
fputs(timeStr, fp);
|
||
|
fputs("] ", fp);
|
||
|
fputs("[", fp);
|
||
|
fputs(className, fp);
|
||
|
fputs("]: ", fp);
|
||
|
fputs(message, fp);
|
||
|
}
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
void dLogger::Log(const std::string & className, const std::string & message) {
|
||
|
Log(className.c_str(), message.c_str());
|
||
|
}
|
||
|
|
||
|
void dLogger::Flush() {
|
||
|
#ifdef _WIN32
|
||
|
mFile.flush();
|
||
|
#else
|
||
|
if (fp != nullptr) {
|
||
|
std::fflush(fp);
|
||
|
}
|
||
|
#endif
|
||
|
}
|