...
This commit is contained in:
parent
7251f95459
commit
05e0055193
@ -13,6 +13,101 @@
|
|||||||
namespace adc
|
namespace adc
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
/* SPDLOG-library based advanced single/multithreaded logger */
|
||||||
|
|
||||||
|
class AdcSPDLOGLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
// [year-month-day time.millisecs] [log-level]: log-message
|
||||||
|
constexpr static std::string_view LOGGER_DEFAULT_FORMAT = "[%Y-%m-%d %T.%e] [%l]: %v";
|
||||||
|
|
||||||
|
typedef spdlog::level::level_enum loglevel_t;
|
||||||
|
|
||||||
|
AdcSPDLOGLogger(std::shared_ptr<spdlog::logger> logger,
|
||||||
|
const traits::adc_input_char_range auto& pattern = LOGGER_DEFAULT_FORMAT)
|
||||||
|
: _loggerSPtr(logger), _currentLogPattern(pattern)
|
||||||
|
{
|
||||||
|
_loggerSPtr->set_pattern(_currentLogPattern);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
virtual ~AdcSPDLOGLogger() = default;
|
||||||
|
|
||||||
|
|
||||||
|
void setLogLevel(loglevel_t log_level)
|
||||||
|
{
|
||||||
|
_loggerSPtr->set_level(log_level);
|
||||||
|
}
|
||||||
|
|
||||||
|
loglevel_t getLogLevel() const
|
||||||
|
{
|
||||||
|
return _loggerSPtr->level();
|
||||||
|
}
|
||||||
|
|
||||||
|
void logMessage(loglevel_t level, std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
_loggerSPtr->log(level, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
// specialized for given level methods
|
||||||
|
|
||||||
|
void logCritical(std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
logMessage(spdlog::level::critical, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logError(std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
logMessage(spdlog::level::err, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logWarn(std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
logMessage(spdlog::level::warn, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logInfo(std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
logMessage(spdlog::level::info, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logDebug(std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
logMessage(spdlog::level::debug, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
void logTrace(std::string_view fmt, traits::formattable auto&&... args)
|
||||||
|
{
|
||||||
|
logMessage(spdlog::level::trace, fmt, std::forward<decltype(args)>(args)...);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
static constexpr size_t LOGGER_DEFAULT_FORMAT_MARK_POS = 21;
|
||||||
|
|
||||||
|
std::string _currentLogPattern;
|
||||||
|
std::shared_ptr<spdlog::logger> _loggerSPtr;
|
||||||
|
|
||||||
|
|
||||||
|
// helper method
|
||||||
|
void addMarkToPattern(traits::adc_input_char_range auto& mark, size_t pos = LOGGER_DEFAULT_FORMAT_MARK_POS)
|
||||||
|
{
|
||||||
|
std::string ptrn = _currentLogPattern.substr(0, pos);
|
||||||
|
|
||||||
|
ptrn += " [";
|
||||||
|
std::ranges::copy(mark, std::back_inserter(ptrn));
|
||||||
|
ptrn += "] ";
|
||||||
|
|
||||||
|
std::ranges::copy(_currentLogPattern | std::views::drop(pos), std::back_inserter(ptrn));
|
||||||
|
|
||||||
|
_currentLogPattern = ptrn;
|
||||||
|
|
||||||
|
_loggerSPtr->set_pattern(_currentLogPattern);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
template <typename BaseT>
|
template <typename BaseT>
|
||||||
class AdcSpdlogGenericDecorator : public BaseT
|
class AdcSpdlogGenericDecorator : public BaseT
|
||||||
{
|
{
|
||||||
@ -77,7 +172,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <traits::formattable... ArgTs>
|
template <traits::formattable... ArgTs>
|
||||||
void logMsg(spdlog::level::level_enum level, std::string_view fmt, ArgTs&&... args)
|
void logMessage(spdlog::level::level_enum level, std::string_view fmt, ArgTs&&... args)
|
||||||
{
|
{
|
||||||
_logger->log(level, fmt, std::forward<ArgTs>(args)...);
|
_logger->log(level, fmt, std::forward<ArgTs>(args)...);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -686,7 +686,7 @@ public:
|
|||||||
typedef CharTraitsT char_traits_t;
|
typedef CharTraitsT char_traits_t;
|
||||||
|
|
||||||
enum loglevel_t { NULL_LEVEL, ERROR_LEVEL, INFO_LEVEL, DEBUG_LEVEL };
|
enum loglevel_t { NULL_LEVEL, ERROR_LEVEL, INFO_LEVEL, DEBUG_LEVEL };
|
||||||
static constexpr std::array logLevelMark{"null", "error", "info", "debug"};
|
static constexpr std::array LOGLEVEL_MARK{"null", "error", "info", "debug"};
|
||||||
|
|
||||||
AdcOstreamLogger(std::basic_ostream<CharT, CharTraitsT>& stream = std::cout, loglevel_t log_level = INFO_LEVEL)
|
AdcOstreamLogger(std::basic_ostream<CharT, CharTraitsT>& stream = std::cout, loglevel_t log_level = INFO_LEVEL)
|
||||||
: _logStream(stream), _currentLogLevel(log_level)
|
: _logStream(stream), _currentLogLevel(log_level)
|
||||||
@ -725,7 +725,7 @@ public:
|
|||||||
// format log-message in form:
|
// format log-message in form:
|
||||||
// [YYYY-MM-DD HH:MM:SS][level] log-message
|
// [YYYY-MM-DD HH:MM:SS][level] log-message
|
||||||
//
|
//
|
||||||
_logStream << std::put_time(std::localtime(&now), "[%F %T]") << "[" << logLevelMark[_currentLogLevel] << "] "
|
_logStream << std::put_time(std::localtime(&now), "[%F %T]") << "[" << LOGLEVEL_MARK[_currentLogLevel] << "] "
|
||||||
<< s;
|
<< s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -236,6 +236,9 @@ concept adc_logger_c = requires(LOGGERT log, const LOGGERT log_const) {
|
|||||||
// logging method signature:
|
// logging method signature:
|
||||||
// void method(std::string_view fmt, traits::formattable auto&& args...)
|
// void method(std::string_view fmt, traits::formattable auto&& args...)
|
||||||
|
|
||||||
|
log.logMessage(std::declval<typename LOGGERT::loglevel_t>(), std::declval<std::string_view>());
|
||||||
|
log.logMessage(std::declval<typename LOGGERT::loglevel_t>(), std::declval<std::string_view>(),
|
||||||
|
std::declval<std::string>());
|
||||||
|
|
||||||
// logging method must accept at least the single argument - formatting string
|
// logging method must accept at least the single argument - formatting string
|
||||||
log.logInfo(std::declval<std::string_view>());
|
log.logInfo(std::declval<std::string_view>());
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user