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
|
/* 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 log records to the MSVC debug system.
* Does nothing on compilers != MSVC.
*/
#ifdef _MSC_VER
#include "Backend.h"
#include "FramePrefixer.h"
#include <windows.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name logging_sink_outputDebugString
* ILog.h sink implementation for the MSVC debug system.
*/
///@{
/// Records a log entry
static void log_sink_record_outputDebugString(const char* section, int level,
const char* record)
{
char framePrefix[128] = {'\0'};
log_framePrefixer_createPrefix(framePrefix, sizeof(framePrefix));
OutputDebugString(framePrefix);
OutputDebugString(record);
OutputDebugString("\n");
}
///@}
namespace {
/// Auto-registers the sink defined in this file before main() is called
struct OutputDebugStringSinkRegistrator {
OutputDebugStringSinkRegistrator() {
log_backend_registerSink(&log_sink_record_outputDebugString);
}
~OutputDebugStringSinkRegistrator() {
log_backend_unregisterSink(&log_sink_record_outputDebugString);
}
} outputDebugStringSinkRegistrator;
}
#ifdef __cplusplus
} // extern "C"
#endif
#endif // _MSC_VER
|