Files
MuditaOS/module-utils/log/Logger.cpp
Mateusz Grzegorzek 0b75c6299d [EGD-4873] Add colors to rt1051 logs
Bring back possibility to get colorful logs from rt1051.
Colored logs can be now turned on in runtime using
Logger::enableColors method.
2021-02-10 18:19:32 +01:00

120 lines
3.6 KiB
C++

// Copyright (c) 2017-2021, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#include "critical.hpp"
#include <fstream>
#include <gsl/gsl_util>
#include "Logger.hpp"
#include "macros.h"
namespace Log
{
std::map<std::string, logger_level> Logger::filtered = {{"ApplicationManager", logger_level::LOGINFO},
{"TS0710Worker", logger_level::LOGINFO},
{"ServiceCellular", logger_level::LOGINFO},
{"ServiceAntenna", logger_level::LOGINFO},
{"ServiceFota", logger_level::LOGINFO},
{"ServiceEink", logger_level::LOGINFO},
{"ServiceDB", logger_level::LOGINFO},
{CRIT_STR, logger_level::LOGTRACE},
{IRQ_STR, logger_level::LOGTRACE}};
const char *Logger::level_names[] = {"TRACE", "DEBUG", "INFO", "WARN", "ERROR", "FATAL"};
void Logger::enableColors(bool enable)
{
if (!lock()) {
return;
}
auto _ = gsl::finally([this] { unlock(); });
if (enable) {
logColors = &logColorsOn;
}
else {
logColors = &logColorsOff;
}
}
auto Logger::GetLogLevel(const std::string &name) -> logger_level
{
return filtered[name];
}
bool Logger::lock()
{
if (isIRQ()) {
bt = cpp_freertos::CriticalSection::EnterFromISR();
}
else {
return mutex.Lock();
}
return true;
}
void Logger::init()
{
#if LOG_USE_COLOR == 1
enableColors(true);
#else
enableColors(false);
#endif
}
auto Logger::log(Device device, const char *fmt, va_list args) -> int
{
if (!lock()) {
return -1;
}
auto _ = gsl::finally([this] { unlock(); });
loggerBufferCurrentPos = 0;
loggerBufferCurrentPos += vsnprintf(&loggerBuffer[loggerBufferCurrentPos], loggerBufferSizeLeft(), fmt, args);
logToDevice(device, loggerBuffer, loggerBufferCurrentPos);
return loggerBufferCurrentPos;
}
void Logger::log(
logger_level level, const char *file, int line, const char *function, const char *fmt, va_list args)
{
if (!filterLogs(level)) {
return;
}
if (!lock()) {
return;
}
auto _ = gsl::finally([this] { unlock(); });
loggerBufferCurrentPos = 0;
addLogHeader(level, file, line, function);
loggerBufferCurrentPos += vsnprintf(&loggerBuffer[loggerBufferCurrentPos], loggerBufferSizeLeft(), fmt, args);
loggerBufferCurrentPos += snprintf(&loggerBuffer[loggerBufferCurrentPos], loggerBufferSizeLeft(), "\n");
logToDevice(Device::DEFAULT, loggerBuffer, loggerBufferCurrentPos);
}
auto Logger::logAssert(const char *fmt, va_list args) -> int
{
if (!lock()) {
return -1;
}
auto _ = gsl::finally([this] { unlock(); });
logToDevice(fmt, args);
return loggerBufferCurrentPos;
}
void Logger::unlock()
{
if (isIRQ()) {
cpp_freertos::CriticalSection::ExitFromISR(bt);
}
else {
mutex.Unlock();
}
}
}; // namespace Log