diff options
author | gabime <gmelman1@gmail.com> | 2018-06-24 01:32:39 +0300 |
---|---|---|
committer | gabime <gmelman1@gmail.com> | 2018-06-24 01:32:39 +0300 |
commit | 0c19bdd7725028fe07751bbef02bdf1326829591 (patch) | |
tree | 49ba289501768ec431b741791d243e46eb7b517f /include/spdlog/formatter.h | |
parent | 9d7a5c253a05566c366e1a9352c3c00cc78e0f27 (diff) |
pattern per sink and pattern caching
Diffstat (limited to 'include/spdlog/formatter.h')
-rw-r--r-- | include/spdlog/formatter.h | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/include/spdlog/formatter.h b/include/spdlog/formatter.h index 8641491d..af54e88c 100644 --- a/include/spdlog/formatter.h +++ b/include/spdlog/formatter.h @@ -5,6 +5,7 @@ #pragma once +#include "fmt/fmt.h" #include "spdlog/details/log_msg.h" #include <memory> @@ -12,31 +13,32 @@ #include <vector> namespace spdlog { -namespace details { -class flag_formatter; -} class formatter { public: virtual ~formatter() = default; - virtual void format(details::log_msg &msg) = 0; + virtual void format(const details::log_msg &msg, fmt::memory_buffer &dest) = 0; }; +namespace details { +class flag_formatter; +} + class pattern_formatter SPDLOG_FINAL : public formatter { public: 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; + pattern_formatter(const pattern_formatter &) = default; + pattern_formatter &operator=(const pattern_formatter &) = default; + void format(const details::log_msg &msg, fmt::memory_buffer &dest) override; private: const std::string eol_; const pattern_time_type pattern_time_; std::vector<std::unique_ptr<details::flag_formatter>> formatters_; - std::tm get_time(details::log_msg &msg); + std::tm get_time(const details::log_msg &msg); void handle_flag(char flag); void compile_pattern(const std::string &pattern); }; |