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
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
#include "LogSinkHandler.h"
#include "Backend.h"
#include <string>
#include <cassert>
/// Records a log entry
static void log_sink_record_logSinkHandler(const char* section, int level,
const char* record)
{
logSinkHandler.RecordLogMessage((section == NULL) ? "" : section, level, record);
}
void LogSinkHandler::AddSink(ILogSink* logSink) {
assert(logSink != NULL);
if (sinks.empty()) {
log_backend_registerSink(&log_sink_record_logSinkHandler);
}
sinks.insert(logSink);
}
void LogSinkHandler::RemoveSink(ILogSink* logSink) {
assert(logSink != NULL);
sinks.erase(logSink);
if (sinks.empty()) {
log_backend_unregisterSink(&log_sink_record_logSinkHandler);
}
}
void LogSinkHandler::RecordLogMessage(const std::string& section, int level,
const std::string& text) const
{
if (!sinking)
return;
for (auto lsi = sinks.begin(); lsi != sinks.end(); ++lsi) {
(*lsi)->RecordLogMessage(section, level, text);
}
}
|