spdlog/include/spitlog/common.h
gabi cbddc8796a 1. renamed lib to to spitlog
2. Rotating bugfix
2014-10-30 00:11:06 +02:00

56 lines
992 B
C++

#pragma once
#include<initializer_list>
#include<chrono>
namespace spitlog
{
class formatter;
namespace sinks {
class sink;
}
// Common types across the lib
using log_clock = std::chrono::system_clock;
using sink_ptr = std::shared_ptr < sinks::sink > ;
using sinks_init_list = std::initializer_list < sink_ptr > ;
using formatter_ptr = std::shared_ptr<spitlog::formatter>;
//Log level enum
namespace level
{
typedef enum
{
TRACE,
DEBUG,
INFO,
WARN,
ERR,
CRITICAL,
NONE = 99
} level_enum;
static const char* level_names[] { "trace", "debug", "info", "warning", "error", "critical", "fatal" };
inline const char* to_str(spitlog::level::level_enum l)
{
return level_names[l];
}
} //level
//
// Log exception
//
class fflog_exception : public std::exception
{
public:
fflog_exception(const std::string& msg) :_msg(msg) {};
const char* what() const throw() override {
return _msg.c_str();
}
private:
std::string _msg;
};
} //spitlog