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_base.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_base.cc')
| -rw-r--r-- | src/logger_base.cc | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/src/logger_base.cc b/src/logger_base.cc new file mode 100644 index 0000000..51f13b9 --- /dev/null +++ b/src/logger_base.cc @@ -0,0 +1,69 @@ +#include "common.hh" + +#include "logger_base.hh" + +#include <stdarg.h> +#include <stdio.h> +#include <stdlib.h> + +void LoggerBase::err(char const* format, ...) { + va_list args; + va_start(args, format); + char* tmp = nullptr; + auto len = vasprintf(&tmp, format, args); + va_end(args); + if (len == -1) { + assert(false); + return; + } + while (len > 0 && tmp[len - 1] == '\n') --len; + msg(Level::ERR, std::string_view(tmp, len)); + free(tmp); +} + +void LoggerBase::warn(char const* format, ...) { + va_list args; + va_start(args, format); + char* tmp = nullptr; + auto len = vasprintf(&tmp, format, args); + va_end(args); + if (len == -1) { + assert(false); + return; + } + while (len > 0 && tmp[len - 1] == '\n') --len; + msg(Level::WARN, std::string_view(tmp, len)); + free(tmp); +} + +void LoggerBase::info(char const* format, ...) { + va_list args; + va_start(args, format); + char* tmp = nullptr; + auto len = vasprintf(&tmp, format, args); + va_end(args); + if (len == -1) { + assert(false); + return; + } + while (len > 0 && tmp[len - 1] == '\n') --len; + msg(Level::INFO, std::string_view(tmp, len)); + free(tmp); +} + +#ifndef NDEBUG +void LoggerBase::dbg(char const* format, ...) { + va_list args; + va_start(args, format); + char* tmp = nullptr; + auto len = vasprintf(&tmp, format, args); + va_end(args); + if (len == -1) { + assert(false); + return; + } + while (len > 0 && tmp[len - 1] == '\n') --len; + msg(Level::DBG, std::string_view(tmp, len)); + free(tmp); +} +#endif |
