File: LogWriter.cpp

package info (click to toggle)
darkradiant 3.9.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 41,080 kB
  • sloc: cpp: 264,743; ansic: 10,659; python: 1,852; xml: 1,650; sh: 92; makefile: 21
file content (77 lines) | stat: -rw-r--r-- 1,513 bytes parent folder | download | duplicates (4)
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
#include "LogWriter.h"

#include <cassert>
#include <tuple>
#include "StringLogDevice.h"

namespace applog
{

LogWriter::LogWriter()
{
	for (auto level : AllLogLevels)
	{
        _streams.emplace(level, std::make_unique<LogStream>(level));
	}
}

void LogWriter::write(const char* p, std::size_t length, LogLevel level)
{
	// Convert the buffer to a string
	std::string output(p, length);

	// Visit all the logfiles and write the string
	for (auto device : _devices)
    {
		device->writeLog(output, level);
	}
}

std::ostream& LogWriter::getLogStream(LogLevel level)
{
	assert(_streams.find(level) != _streams.end());
	return *_streams.at(level);
}

std::mutex& LogWriter::getStreamLock()
{
	return LogStream::GetStreamLock();
}

void LogWriter::attach(ILogDevice* device)
{
	_devices.insert(device);

	if (device->isConsole())
	{
		// The first console device receives all the buffered output
		if (applog::StringLogDevice::InstancePtr())
		{
			applog::StringLogDevice& logger = *applog::StringLogDevice::InstancePtr();

			for (auto level : applog::AllLogLevels)
			{
				std::string bufferedText = logger.getString(static_cast<applog::LogLevel>(level));

				if (bufferedText.empty()) continue;

				device->writeLog(bufferedText + "\n", static_cast<applog::LogLevel>(level));
			}
		}

		applog::StringLogDevice::destroy();
	}
}

void LogWriter::detach(ILogDevice* device)
{
	_devices.erase(device);
}

LogWriter& LogWriter::Instance()
{
	static LogWriter _writer;
	return _writer;
}

} // namespace applog