34 lines
837 B
C++
34 lines
837 B
C++
#pragma once
|
|
|
|
#include "tools/EnumConverter.h"
|
|
#include "Sink.h"
|
|
#include "Level.h"
|
|
|
|
namespace logging {
|
|
|
|
void addSink(std::shared_ptr<Sink> sink);
|
|
|
|
void log(Level level, const std::string& message);
|
|
|
|
template <typename... Args>
|
|
void logFormat(Level level, fmt::CStringRef format, const Args&... args) {
|
|
log(level, fmt::format(format, args...));
|
|
}
|
|
|
|
#define LOG_WITH_LEVEL(levelName, levelEnum) \
|
|
inline void levelName(const std::string& message) { \
|
|
log(Level::levelEnum, message); \
|
|
} \
|
|
template <typename... Args> \
|
|
void levelName ## Format(fmt::CStringRef format, const Args&... args) { \
|
|
logFormat(Level::levelEnum, format, args...); \
|
|
}
|
|
|
|
LOG_WITH_LEVEL(trace, Trace)
|
|
LOG_WITH_LEVEL(debug, Debug)
|
|
LOG_WITH_LEVEL(info, Info)
|
|
LOG_WITH_LEVEL(warn, Warn)
|
|
LOG_WITH_LEVEL(error, Error)
|
|
LOG_WITH_LEVEL(fatal, Fatal)
|
|
}
|