/* */ #include "SimpleLogger.h" #include "Util.h" #include "DlAbortEx.h" #include "message.h" #include #include #include #include #define WRITE_LOG(LEVEL, MSG) \ va_list ap;\ va_start(ap, MSG);\ writeLog(Logger::LEVEL, MSG, ap);\ va_end(ap); #define WRITE_LOG_EX(LEVEL, MSG, EX) \ va_list ap;\ va_start(ap, EX);\ writeLog(Logger::LEVEL, MSG, ap, EX);\ va_end(ap); SimpleLogger::SimpleLogger():file(NULL) {} SimpleLogger::SimpleLogger(FILE* logfile) { file = logfile; } SimpleLogger::~SimpleLogger() { closeFile(); } void SimpleLogger::openFile(const string& filename) { file = fopen(filename.c_str(), "a"); if(file == NULL) { throw new DlAbortEx(EX_FILE_OPEN, filename.c_str(), strerror(errno)); } } void SimpleLogger::closeFile() { if(file != NULL) { fclose(file); } } void SimpleLogger::writeHeader(string date, string level) const { fprintf(file, "%s - %s - ", date.c_str(), level.c_str()); } void SimpleLogger::writeLog(int level, const char* msg, va_list ap, Exception* e) const { string levelStr; switch(level) { case Logger::DEBUG: levelStr = "DEBUG"; break; case Logger::WARN: levelStr = "WARN"; break; case Logger::ERROR: levelStr = "ERROR"; break; case Logger::INFO: default: levelStr = "INFO"; } time_t now = time(NULL); char datestr[26]; ctime_r(&now, datestr); datestr[strlen(datestr)-1] = '\0'; writeHeader(datestr, levelStr); vfprintf(file, string(Util::replace(msg, "\r", "")+"\n").c_str(), ap); if(e != NULL) { writeHeader(datestr, levelStr); fprintf(file, "exception: %s\n", Util::replace(e->getMsg(), "\r", "").c_str()); } fflush(file); } void SimpleLogger::debug(const char* msg, ...) const { WRITE_LOG(DEBUG, msg); } void SimpleLogger::debug(const char* msg, Exception* e, ...) const { WRITE_LOG_EX(DEBUG, msg, e); } void SimpleLogger::info(const char* msg, ...) const { WRITE_LOG(INFO, msg); } void SimpleLogger::info(const char* msg, Exception* e, ...) const { WRITE_LOG_EX(INFO, msg, e); } void SimpleLogger::warn(const char* msg, ...) const { WRITE_LOG(WARN, msg); } void SimpleLogger::warn(const char* msg, Exception* e, ...) const { WRITE_LOG_EX(WARN, msg, e); } void SimpleLogger::error(const char* msg, ...) const { WRITE_LOG(ERROR, msg); } void SimpleLogger::error(const char* msg, Exception* e, ...) const { WRITE_LOG_EX(ERROR, msg, e); }