diff options
| author | Joel Klinghed <the_jk@spawned.biz> | 2025-02-20 22:54:56 +0100 |
|---|---|---|
| committer | Joel Klinghed <the_jk@spawned.biz> | 2025-02-20 22:54:56 +0100 |
| commit | b4d6df902253637f24647d3db2bc3781d69eec1c (patch) | |
| tree | d8bf9ac04a270fabdfee1c15628c702471ef8bf5 /src/logger_base.cc | |
| parent | 441cafc7124f633e5abc684e85a11ce3c991f6ae (diff) | |
Diffstat (limited to 'src/logger_base.cc')
| -rw-r--r-- | src/logger_base.cc | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/src/logger_base.cc b/src/logger_base.cc new file mode 100644 index 0000000..0bd4e98 --- /dev/null +++ b/src/logger_base.cc @@ -0,0 +1,68 @@ +#include "logger_base.hh" + +#include <cassert> +#include <cstdarg> +#include <cstdio> +#include <cstdlib> + +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 |
