2016-08-14 19:43:34 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <fmt/format.h>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "logging/log.hpp"
|
|
|
|
|
|
|
|
// TODO: in c++17 replace with logging::format
|
|
|
|
namespace logging
|
|
|
|
{
|
|
|
|
namespace format
|
|
|
|
{
|
2016-10-16 02:16:32 +08:00
|
|
|
static const std::string out = "{} {:<5} [{}] {}\n";
|
|
|
|
static const std::string err = out;
|
2016-08-14 19:43:34 +08:00
|
|
|
|
|
|
|
// TODO: configurable formats
|
|
|
|
}
|
|
|
|
|
|
|
|
class Formatter
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static std::string format(const std::string &format,
|
|
|
|
const Log::Record &record)
|
|
|
|
{
|
|
|
|
return fmt::format(format, static_cast<std::string>(record.when()),
|
|
|
|
record.level_str(), record.where(),
|
|
|
|
record.text());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|