2016-05-10 05:30:13 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-08-02 05:14:09 +08:00
|
|
|
#include <cassert>
|
|
|
|
#include <fmt/format.h>
|
|
|
|
|
2016-08-10 16:39:02 +08:00
|
|
|
#include "logging/log.hpp"
|
|
|
|
#include "logging/levels.hpp"
|
2016-05-10 05:30:13 +08:00
|
|
|
|
|
|
|
class Logger
|
|
|
|
{
|
|
|
|
template <class Level>
|
|
|
|
class Message : public Log::Record
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Message(Timestamp timestamp, std::string location, std::string message)
|
|
|
|
: timestamp(timestamp), location(location), message(message) {}
|
|
|
|
|
|
|
|
const Timestamp& when() const override
|
|
|
|
{
|
|
|
|
return timestamp;
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::string& where() const override
|
|
|
|
{
|
|
|
|
return location;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned level() const override
|
|
|
|
{
|
|
|
|
return Level::level;
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::string& level_str() const override
|
|
|
|
{
|
|
|
|
return Level::text;
|
|
|
|
}
|
|
|
|
|
|
|
|
const std::string& text() const override
|
|
|
|
{
|
|
|
|
return message;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Timestamp timestamp;
|
|
|
|
std::string location;
|
|
|
|
std::string message;
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
2016-08-02 05:14:09 +08:00
|
|
|
Logger() = default;
|
|
|
|
|
|
|
|
Logger(Log* log, const std::string& name) : log(log), name(name) {}
|
2016-05-10 05:30:13 +08:00
|
|
|
|
|
|
|
template <class Level, class... Args>
|
|
|
|
void emit(Args&&... args)
|
|
|
|
{
|
2016-08-02 05:14:09 +08:00
|
|
|
assert(log != nullptr);
|
|
|
|
|
2016-05-10 05:30:13 +08:00
|
|
|
auto message = std::make_unique<Message<Level>>(
|
|
|
|
Timestamp::now(), name, fmt::format(std::forward<Args>(args)...)
|
|
|
|
);
|
|
|
|
|
2016-08-02 05:14:09 +08:00
|
|
|
log->emit(std::move(message));
|
2016-05-10 05:30:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class... Args>
|
|
|
|
void trace(Args&&... args)
|
|
|
|
{
|
2016-08-02 05:14:09 +08:00
|
|
|
#ifndef NDEBUG
|
|
|
|
#ifndef LOG_NO_TRACE
|
2016-05-10 05:30:13 +08:00
|
|
|
emit<Trace>(std::forward<Args>(args)...);
|
2016-08-02 05:14:09 +08:00
|
|
|
#endif
|
|
|
|
#endif
|
2016-05-10 05:30:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class... Args>
|
|
|
|
void debug(Args&&... args)
|
|
|
|
{
|
2016-11-29 11:08:08 +08:00
|
|
|
#ifndef NDEBUG
|
2016-08-02 05:14:09 +08:00
|
|
|
#ifndef LOG_NO_DEBUG
|
2016-05-10 05:30:13 +08:00
|
|
|
emit<Debug>(std::forward<Args>(args)...);
|
2016-11-29 11:08:08 +08:00
|
|
|
#endif
|
2016-08-02 05:14:09 +08:00
|
|
|
#endif
|
2016-05-10 05:30:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class... Args>
|
|
|
|
void info(Args&&... args)
|
|
|
|
{
|
2016-08-02 05:14:09 +08:00
|
|
|
#ifndef LOG_NO_INFO
|
2016-05-10 05:30:13 +08:00
|
|
|
emit<Info>(std::forward<Args>(args)...);
|
2016-08-02 05:14:09 +08:00
|
|
|
#endif
|
2016-05-10 05:30:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class... Args>
|
|
|
|
void warn(Args&&... args)
|
|
|
|
{
|
2016-08-02 05:14:09 +08:00
|
|
|
#ifndef LOG_NO_WARN
|
2016-05-10 05:30:13 +08:00
|
|
|
emit<Warn>(std::forward<Args>(args)...);
|
2016-08-02 05:14:09 +08:00
|
|
|
#endif
|
2016-05-10 05:30:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
template <class... Args>
|
|
|
|
void error(Args&&... args)
|
|
|
|
{
|
2016-08-02 05:14:09 +08:00
|
|
|
#ifndef LOG_NO_ERROR
|
2016-05-10 05:30:13 +08:00
|
|
|
emit<Error>(std::forward<Args>(args)...);
|
2016-08-02 05:14:09 +08:00
|
|
|
#endif
|
2016-05-10 05:30:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2016-08-02 05:14:09 +08:00
|
|
|
Log* log;
|
2016-05-10 05:30:13 +08:00
|
|
|
std::string name;
|
|
|
|
};
|