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
|
/* This file is part of the Spring engine (GPL v2 or later), see LICENSE.html */
#include "LogSinkHandler.h"
#include "Backend.h"
#include <string>
#include <vector>
#include <cassert>
LogSinkHandler logSinkHandler;
/// 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);
}
LogSinkHandler::LogSinkHandler()
: sinking(true)
{
}
LogSinkHandler::~LogSinkHandler() {
if (!sinks.empty()) {
log_backend_unregisterSink(&log_sink_record_logSinkHandler);
}
}
void LogSinkHandler::AddSink(ILogSink* logSink) {
assert(logSink != NULL);
sinks.push_back(logSink);
if (sinks.size() == 1) {
log_backend_registerSink(&log_sink_record_logSinkHandler);
}
}
void LogSinkHandler::RemoveSink(ILogSink* logSink) {
assert(logSink != NULL);
std::vector<ILogSink*>::iterator lsi;
for (lsi = sinks.begin(); lsi != sinks.end(); ++lsi) {
if (*lsi == logSink) {
sinks.erase(lsi);
break;
}
}
if (sinks.empty()) {
log_backend_unregisterSink(&log_sink_record_logSinkHandler);
}
}
void LogSinkHandler::SetSinking(bool enabled) {
this->sinking = enabled;
}
bool LogSinkHandler::IsSinking() const {
return sinking;
}
void LogSinkHandler::RecordLogMessage(const std::string& section, int level,
const std::string& text) const
{
if (!sinking) {
return;
}
std::vector<ILogSink*>::const_iterator lsi;
for (lsi = sinks.begin(); lsi != sinks.end(); ++lsi) {
(*lsi)->RecordLogMessage(section, level, text);
}
}
|