From b4d6df902253637f24647d3db2bc3781d69eec1c Mon Sep 17 00:00:00 2001 From: Joel Klinghed Date: Thu, 20 Feb 2025 22:54:56 +0100 Subject: Initial commit --- src/logger_stdio.cc | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 src/logger_stdio.cc (limited to 'src/logger_stdio.cc') diff --git a/src/logger_stdio.cc b/src/logger_stdio.cc new file mode 100644 index 0000000..e1f26d2 --- /dev/null +++ b/src/logger_stdio.cc @@ -0,0 +1,39 @@ +#include "logger_base.hh" + +#include +#include + +namespace { + +class LoggerStdio : public LoggerBase { +public: + LoggerStdio() = default; + +protected: + void msg(Level lvl, std::string_view msg) override { + std::lock_guard lock(mutex_); + switch (lvl) { + case Level::ERR: + std::cerr << "Error: " << msg << std::endl; + break; + case Level::WARN: + std::cout << "Warning: " << msg << std::endl; + break; + case Level::INFO: + std::cout << msg << std::endl; + break; + case Level::DBG: + std::cout << "Debug: " << msg << std::endl; + break; + } + } + +private: + std::mutex mutex_; +}; + +} // namespace + +std::unique_ptr Logger::create_stdio() { + return std::make_unique(); +} -- cgit v1.2.3-70-g09d2