1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
/**
* This is a simple sink for the ILog.h logging API.
* It routes all logging messages to the console (stdout & stderr).
*/
#include "Backend.h"
#include "FramePrefixer.h"
#include "Level.h" // for LOG_LEVEL_*
#include "System/maindefines.h"
#include <cstdio>
#ifdef __cplusplus
extern "C" {
#endif
static bool colorizedOutput = false;
/**
* @name logging_sink_console
* ILog.h sink implementation.
*/
///@{
void log_console_colorizedOutput(bool enable) {
colorizedOutput = enable;
}
/// Records a log entry
static void log_sink_record_console(const char* section, int level,
const char* record)
{
char framePrefix[128] = {'\0'};
log_framePrefixer_createPrefix(framePrefix, sizeof(framePrefix));
FILE* outStream = (level >= LOG_LEVEL_WARNING)? stderr: stdout;
const char* fstr = "%s%s\n";
if (colorizedOutput) {
if (level >= LOG_LEVEL_ERROR) {
fstr = "\033[90m%s\033[31m%s\033[39m\n";
} else if (level >= LOG_LEVEL_WARNING) {
fstr = "\033[90m%s\033[33m%s\033[39m\n";
} else {
fstr = "\033[90m%s\033[39m%s\n";
}
}
FPRINTF(outStream, fstr, framePrefix, record);
// *printf does not always flush after a newline
// (eg. if stdout is being redirected to a file)
fflush(outStream);
}
///@}
namespace {
/// Auto-registers the sink defined in this file before main() is called
struct ConsoleSinkRegistrator {
ConsoleSinkRegistrator() {
log_backend_registerSink(&log_sink_record_console);
}
~ConsoleSinkRegistrator() {
log_backend_unregisterSink(&log_sink_record_console);
}
} consoleSinkRegistrator;
}
#ifdef __cplusplus
} // extern "C"
#endif
|