Fix a segment fault of logger.

master
Chunting Gu 7 years ago
parent 8faa45defe
commit 2e2b45dd43

@ -121,38 +121,53 @@ static std::string GetThreadID() {
return ss.str();
}
static void WriteToFile(FILE* fd, int level, const char* file, int line,
const char* format, va_list args) {
std::lock_guard<std::mutex> lock(g_logger.mutex);
void LogWrite(int level, const char* file, int line, const char* format, ...) {
assert(format != nullptr);
fprintf(fd, "%s, %s, %7s, %24s, %4d, ",
GetTimestamp().c_str(), kLevelNames[level], GetThreadID().c_str(),
file, line);
std::string timestamp = GetTimestamp();
std::string thread_id = GetThreadID();
vfprintf(fd, format, args);
if ((g_logger.modes & LOG_FILE) != 0 && g_logger.file != nullptr) {
std::lock_guard<std::mutex> lock(g_logger.mutex);
fprintf(fd, "\n");
va_list args;
va_start(args, format);
if ((g_logger.modes & LOG_FLUSH) != 0) {
fflush(fd);
}
}
fprintf(g_logger.file, "%s, %s, %7s, %24s, %4d, ",
timestamp.c_str(), kLevelNames[level], thread_id.c_str(),
file, line);
void LogWrite(int level, const char* file, int line, const char* format, ...) {
assert(format != nullptr);
vfprintf(g_logger.file, format, args);
va_list args;
va_start(args, format);
fprintf(g_logger.file, "\n");
if ((g_logger.modes & LOG_FILE) != 0 && g_logger.file != nullptr) {
WriteToFile(g_logger.file, level, file, line, format, args);
if ((g_logger.modes & LOG_FLUSH) != 0) {
fflush(g_logger.file);
}
va_end(args);
}
if ((g_logger.modes & LOG_CONSOLE) != 0) {
WriteToFile(stderr, level, file, line, format, args);
}
std::lock_guard<std::mutex> lock(g_logger.mutex);
va_list args;
va_start(args, format);
fprintf(stderr, "%s, %s, %7s, %24s, %4d, ",
timestamp.c_str(), kLevelNames[level], thread_id.c_str(),
file, line);
vfprintf(stderr, format, args);
va_end(args);
fprintf(stderr, "\n");
if ((g_logger.modes & LOG_FLUSH) != 0) {
fflush(stderr);
}
va_end(args);
}
}
} // namespace webcc

Loading…
Cancel
Save