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
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
#include "StreamSink.h"
#include "Backend.h"
#include <ostream>
#include <string>
#include <cstring>
static std::ostream* logStreamInt = NULL;
void log_sink_stream_setLogStream(std::ostream* logStream) {
logStreamInt = logStream;
}
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name logging_sink_stream
* ILog.h sink implementation.
*/
///@{
/// Records a log entry
void log_sink_record_stream(const char* section, int level, const char* record)
{
if (logStreamInt != NULL) {
logStreamInt->write(record, strlen(record));
(*logStreamInt) << std::endl;
}
}
///@}
namespace {
/// Auto-registers the sink defined in this file before main() is called
struct StreamSinkRegistrator {
StreamSinkRegistrator() {
log_backend_registerSink(&log_sink_record_stream);
}
~StreamSinkRegistrator() {
log_backend_unregisterSink(&log_sink_record_stream);
}
} streamSinkRegistrator;
}
#ifdef __cplusplus
} // extern "C"
#endif
|