danicoin/src/Logging/ConsoleLogger.cpp
2016-01-18 15:33:29 +00:00

67 lines
1.8 KiB
C++
Executable file

// Copyright (c) 2011-2016 The Cryptonote developers
// Distributed under the MIT/X11 software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
#include "ConsoleLogger.h"
#include <iostream>
#include <unordered_map>
#include <Common/ConsoleTools.h>
namespace Logging {
using Common::Console::Color;
ConsoleLogger::ConsoleLogger(Level level) : CommonLogger(level) {
}
void ConsoleLogger::doLogString(const std::string& message) {
std::lock_guard<std::mutex> lock(mutex);
bool readingText = true;
bool changedColor = false;
std::string color = "";
static std::unordered_map<std::string, Color> colorMapping = {
{ BLUE, Color::Blue },
{ GREEN, Color::Green },
{ RED, Color::Red },
{ YELLOW, Color::Yellow },
{ WHITE, Color::White },
{ CYAN, Color::Cyan },
{ MAGENTA, Color::Magenta },
{ BRIGHT_BLUE, Color::BrightBlue },
{ BRIGHT_GREEN, Color::BrightGreen },
{ BRIGHT_RED, Color::BrightRed },
{ BRIGHT_YELLOW, Color::BrightYellow },
{ BRIGHT_WHITE, Color::BrightWhite },
{ BRIGHT_CYAN, Color::BrightCyan },
{ BRIGHT_MAGENTA, Color::BrightMagenta },
{ DEFAULT, Color::Default }
};
for (size_t charPos = 0; charPos < message.size(); ++charPos) {
if (message[charPos] == ILogger::COLOR_DELIMETER) {
readingText = !readingText;
color += message[charPos];
if (readingText) {
auto it = colorMapping.find(color);
Common::Console::setTextColor(it == colorMapping.end() ? Color::Default : it->second);
changedColor = true;
color.clear();
}
} else if (readingText) {
std::cout << message[charPos];
} else {
color += message[charPos];
}
}
if (changedColor) {
Common::Console::setTextColor(Color::Default);
}
}
}