Add console logger to replace original debug output.
parent
bcfb1e4c92
commit
662b7c4112
@ -0,0 +1,74 @@
|
||||
#include "webcc/logger.h"
|
||||
|
||||
#if WEBCC_ENABLE_LOG
|
||||
|
||||
#include <cassert>
|
||||
#include <cstdarg>
|
||||
#include <mutex>
|
||||
|
||||
#include "boost/thread.hpp" // For thread ID.
|
||||
|
||||
namespace webcc {
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
static std::string GetThreadId() {
|
||||
boost::thread::id thread_id = boost::this_thread::get_id();
|
||||
std::stringstream ss;
|
||||
ss << thread_id;
|
||||
return ss.str();
|
||||
}
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
static const char* kLevelNames[] = {
|
||||
"VERB", "INFO", "WARN", "ERRO", "FATA"
|
||||
};
|
||||
|
||||
struct Logger {
|
||||
int level;
|
||||
int modes;
|
||||
std::mutex mutex;
|
||||
};
|
||||
|
||||
// Global logger.
|
||||
static Logger g_logger{ VERB };
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
void LogInit(int level, int modes) {
|
||||
g_logger.modes = modes;
|
||||
g_logger.level = level;
|
||||
}
|
||||
|
||||
void LogWrite(int level, const char* file, int line, const char* format, ...) {
|
||||
assert(format != nullptr);
|
||||
|
||||
if (g_logger.level > level) {
|
||||
return;
|
||||
}
|
||||
|
||||
std::lock_guard<std::mutex> lock(g_logger.mutex);
|
||||
|
||||
va_list va_ptr_console;
|
||||
va_start(va_ptr_console, format);
|
||||
|
||||
fprintf(stderr,
|
||||
"%s, %5s, %24s, %4d, ",
|
||||
kLevelNames[level],
|
||||
GetThreadId().c_str(),
|
||||
file,
|
||||
line);
|
||||
vfprintf(stderr, format, va_ptr_console);
|
||||
fprintf(stderr, "\n");
|
||||
|
||||
if ((g_logger.modes & FLUSH) == FLUSH) {
|
||||
fflush(stderr);
|
||||
}
|
||||
|
||||
va_end(va_ptr_console);
|
||||
}
|
||||
|
||||
} // namespace webcc
|
||||
|
||||
#endif // WEBCC_ENABLE_LOG
|
@ -0,0 +1,94 @@
|
||||
#ifndef WEBCC_LOGGER_H_
|
||||
#define WEBCC_LOGGER_H_
|
||||
|
||||
// Simple console logger.
|
||||
|
||||
namespace webcc {
|
||||
|
||||
#if WEBCC_ENABLE_LOG
|
||||
|
||||
enum LogLevel {
|
||||
VERB = 0,
|
||||
INFO,
|
||||
WARN,
|
||||
ERRO,
|
||||
FATA,
|
||||
};
|
||||
|
||||
enum LogMode {
|
||||
FLUSH = 1,
|
||||
};
|
||||
|
||||
void LogInit(int level, int modes);
|
||||
|
||||
void LogWrite(int level, const char* file, int line, const char* format, ...);
|
||||
|
||||
// Initialize the logger with a level.
|
||||
// E.g., LOG_INIT(ERRO, FLUSH)
|
||||
#define LOG_INIT(level, modes) LogInit(level, modes);
|
||||
|
||||
#if (defined(WIN32) || defined(_WIN64))
|
||||
|
||||
// See: https://stackoverflow.com/a/8488201
|
||||
#define __FILENAME__ strrchr("\\" __FILE__, '\\') + 1
|
||||
|
||||
#define LOG_VERB(format, ...) \
|
||||
LogWrite(VERB, __FILENAME__, __LINE__, format, ##__VA_ARGS__);
|
||||
|
||||
#define LOG_INFO(format, ...) \
|
||||
LogWrite(INFO, __FILENAME__, __LINE__, format, ##__VA_ARGS__);
|
||||
|
||||
#define LOG_WARN(format, ...) \
|
||||
LogWrite(WARN, __FILENAME__, __LINE__, format, ##__VA_ARGS__);
|
||||
|
||||
#define LOG_ERRO(format, ...) \
|
||||
LogWrite(ERRO, __FILENAME__, __LINE__, format, ##__VA_ARGS__);
|
||||
|
||||
#define LOG_FATA(format, ...) \
|
||||
LogWrite(FATA, __FILENAME__, __LINE__, format, ##__VA_ARGS__);
|
||||
|
||||
#else
|
||||
|
||||
// See: https://stackoverflow.com/a/8488201
|
||||
#define __FILENAME__ strrchr("/" __FILE__, '/') + 1
|
||||
|
||||
#define LOG_VERB(format, args...) \
|
||||
LogWrite(VERB, __FILENAME__, __LINE__, format, ##args);
|
||||
|
||||
#define LOG_INFO(format, args...) \
|
||||
LogWrite(INFO, __FILENAME__, __LINE__, format, ##args);
|
||||
|
||||
#define LOG_WARN(format, args...) \
|
||||
LogWrite(WARN, __FILENAME__, __LINE__, format, ##args);
|
||||
|
||||
#define LOG_ERRO(format, args...) \
|
||||
LogWrite(ERRO, __FILENAME__, __LINE__, format, ##args);
|
||||
|
||||
#define LOG_FATA(format, args...) \
|
||||
LogWrite(FATA, __FILENAME__, __LINE__, format, ##args);
|
||||
|
||||
#endif // defined(WIN32) || defined(_WIN64)
|
||||
|
||||
#else // WEBCC_ENABLE_LOG == 0
|
||||
|
||||
#define LOG_INIT(level, modes)
|
||||
|
||||
#if (defined(WIN32) || defined(_WIN64))
|
||||
#define LOG_VERB(format, ...)
|
||||
#define LOG_INFO(format, ...)
|
||||
#define LOG_WARN(format, ...)
|
||||
#define LOG_ERRO(format, ...)
|
||||
#define LOG_FATA(format, ...)
|
||||
#else
|
||||
#define LOG_VERB(format, args...)
|
||||
#define LOG_INFO(format, args...)
|
||||
#define LOG_WARN(format, args...)
|
||||
#define LOG_ERRO(format, args...)
|
||||
#define LOG_FATA(format, args...)
|
||||
#endif // defined(WIN32) || defined(_WIN64)
|
||||
|
||||
#endif // WEBCC_ENABLE_LOG
|
||||
|
||||
} // namespace webcc
|
||||
|
||||
#endif // WEBCC_LOGGER_H_
|
Loading…
Reference in New Issue