spdlog/include/spdlog/formatter.h

47 lines
1.2 KiB
C
Raw Normal View History

2016-04-20 16:57:49 +08:00
//
// Copyright(c) 2015 Gabi Melman.
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
//
#pragma once
#include "details/log_msg.h"
2016-04-20 16:57:49 +08:00
#include <memory>
2018-03-09 21:26:33 +08:00
#include <string>
#include <vector>
2016-04-20 16:57:49 +08:00
2018-03-09 21:26:33 +08:00
namespace spdlog {
namespace details {
2016-04-20 16:57:49 +08:00
class flag_formatter;
}
class formatter
{
public:
2018-02-25 06:56:56 +08:00
virtual ~formatter() = default;
2018-03-09 21:26:33 +08:00
virtual void format(details::log_msg &msg) = 0;
2016-04-20 16:57:49 +08:00
};
class pattern_formatter SPDLOG_FINAL : public formatter
2016-04-20 16:57:49 +08:00
{
public:
2018-03-09 21:26:33 +08:00
explicit pattern_formatter(const std::string &pattern, pattern_time_type pattern_time = pattern_time_type::local,
std::string eol = spdlog::details::os::default_eol);
pattern_formatter(const pattern_formatter &) = delete;
pattern_formatter &operator=(const pattern_formatter &) = delete;
void format(details::log_msg &msg) override;
2018-02-25 06:56:56 +08:00
2016-04-20 16:57:49 +08:00
private:
2018-02-05 12:36:54 +08:00
const std::string _eol;
2016-04-20 16:57:49 +08:00
const std::string _pattern;
const pattern_time_type _pattern_time;
2016-04-20 16:57:49 +08:00
std::vector<std::unique_ptr<details::flag_formatter>> _formatters;
2018-03-09 21:26:33 +08:00
std::tm get_time(details::log_msg &msg);
2016-04-20 16:57:49 +08:00
void handle_flag(char flag);
2018-03-09 21:26:33 +08:00
void compile_pattern(const std::string &pattern);
2016-04-20 16:57:49 +08:00
};
2018-03-09 21:26:33 +08:00
} // namespace spdlog
2016-04-20 16:57:49 +08:00
#include "details/pattern_formatter_impl.h"