diff options
| author | Joel Klinghed <the_jk@spawned.biz> | 2021-11-17 22:34:57 +0100 |
|---|---|---|
| committer | Joel Klinghed <the_jk@spawned.biz> | 2021-11-17 22:34:57 +0100 |
| commit | 6232d13f5321b87ddf12a1aa36b4545da45f173d (patch) | |
| tree | 23f3316470a14136debd9d02f9e920ca2b06f4cc /src/logger_stdio.cc | |
Travel3: Simple image and video display site
Reads the images and videos from filesystem and builds a site in
memroy.
Diffstat (limited to 'src/logger_stdio.cc')
| -rw-r--r-- | src/logger_stdio.cc | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/logger_stdio.cc b/src/logger_stdio.cc new file mode 100644 index 0000000..17490a3 --- /dev/null +++ b/src/logger_stdio.cc @@ -0,0 +1,41 @@ +#include "common.hh" + +#include "logger_base.hh" + +#include <iostream> +#include <mutex> + +namespace { + +class LoggerStdio : public LoggerBase { +public: + LoggerStdio() = default; + +protected: + void msg(Level lvl, std::string_view msg) override { + std::lock_guard<std::mutex> 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> Logger::create_stdio() { + return std::make_unique<LoggerStdio>(); +} |
