119 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
		
		
			
		
	
	
			119 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			C
		
	
	
	
|  | // Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
 | ||
|  | // Distributed under the MIT License (http://opensource.org/licenses/MIT)
 | ||
|  | 
 | ||
|  | #pragma once
 | ||
|  | 
 | ||
|  | #include <spdlog/common.h>
 | ||
|  | #include <spdlog/details/log_msg.h>
 | ||
|  | #include <spdlog/details/os.h>
 | ||
|  | #include <spdlog/formatter.h>
 | ||
|  | 
 | ||
|  | #include <chrono>
 | ||
|  | #include <ctime>
 | ||
|  | #include <memory>
 | ||
|  | 
 | ||
|  | #include <string>
 | ||
|  | #include <unordered_map>
 | ||
|  | #include <vector>
 | ||
|  | 
 | ||
|  | namespace spdlog { | ||
|  | namespace details { | ||
|  | 
 | ||
|  | // padding information.
 | ||
|  | struct padding_info { | ||
|  |     enum class pad_side { left, right, center }; | ||
|  | 
 | ||
|  |     padding_info() = default; | ||
|  |     padding_info(size_t width, padding_info::pad_side side, bool truncate) | ||
|  |         : width_(width), | ||
|  |           side_(side), | ||
|  |           truncate_(truncate), | ||
|  |           enabled_(true) {} | ||
|  | 
 | ||
|  |     bool enabled() const { return enabled_; } | ||
|  |     size_t width_ = 0; | ||
|  |     pad_side side_ = pad_side::left; | ||
|  |     bool truncate_ = false; | ||
|  |     bool enabled_ = false; | ||
|  | }; | ||
|  | 
 | ||
|  | class SPDLOG_API flag_formatter { | ||
|  | public: | ||
|  |     explicit flag_formatter(padding_info padinfo) | ||
|  |         : padinfo_(padinfo) {} | ||
|  |     flag_formatter() = default; | ||
|  |     virtual ~flag_formatter() = default; | ||
|  |     virtual void format(const details::log_msg &msg, | ||
|  |                         const std::tm &tm_time, | ||
|  |                         memory_buf_t &dest) = 0; | ||
|  | 
 | ||
|  | protected: | ||
|  |     padding_info padinfo_; | ||
|  | }; | ||
|  | 
 | ||
|  | }  // namespace details
 | ||
|  | 
 | ||
|  | class SPDLOG_API custom_flag_formatter : public details::flag_formatter { | ||
|  | public: | ||
|  |     virtual std::unique_ptr<custom_flag_formatter> clone() const = 0; | ||
|  | 
 | ||
|  |     void set_padding_info(const details::padding_info &padding) { | ||
|  |         flag_formatter::padinfo_ = padding; | ||
|  |     } | ||
|  | }; | ||
|  | 
 | ||
|  | class SPDLOG_API pattern_formatter final : public formatter { | ||
|  | public: | ||
|  |     using custom_flags = std::unordered_map<char, std::unique_ptr<custom_flag_formatter>>; | ||
|  | 
 | ||
|  |     explicit pattern_formatter(std::string pattern, | ||
|  |                                pattern_time_type time_type = pattern_time_type::local, | ||
|  |                                std::string eol = spdlog::details::os::default_eol, | ||
|  |                                custom_flags custom_user_flags = custom_flags()); | ||
|  | 
 | ||
|  |     // use default pattern is not given
 | ||
|  |     explicit pattern_formatter(pattern_time_type time_type = pattern_time_type::local, | ||
|  |                                std::string eol = spdlog::details::os::default_eol); | ||
|  | 
 | ||
|  |     pattern_formatter(const pattern_formatter &other) = delete; | ||
|  |     pattern_formatter &operator=(const pattern_formatter &other) = delete; | ||
|  | 
 | ||
|  |     std::unique_ptr<formatter> clone() const override; | ||
|  |     void format(const details::log_msg &msg, memory_buf_t &dest) override; | ||
|  | 
 | ||
|  |     template <typename T, typename... Args> | ||
|  |     pattern_formatter &add_flag(char flag, Args &&...args) { | ||
|  |         custom_handlers_[flag] = details::make_unique<T>(std::forward<Args>(args)...); | ||
|  |         return *this; | ||
|  |     } | ||
|  |     void set_pattern(std::string pattern); | ||
|  |     void need_localtime(bool need = true); | ||
|  | 
 | ||
|  | private: | ||
|  |     std::string pattern_; | ||
|  |     std::string eol_; | ||
|  |     pattern_time_type pattern_time_type_; | ||
|  |     bool need_localtime_; | ||
|  |     std::tm cached_tm_; | ||
|  |     std::chrono::seconds last_log_secs_; | ||
|  |     std::vector<std::unique_ptr<details::flag_formatter>> formatters_; | ||
|  |     custom_flags custom_handlers_; | ||
|  | 
 | ||
|  |     std::tm get_time_(const details::log_msg &msg); | ||
|  |     template <typename Padder> | ||
|  |     void handle_flag_(char flag, details::padding_info padding); | ||
|  | 
 | ||
|  |     // Extract given pad spec (e.g. %8X)
 | ||
|  |     // Advance the given it pass the end of the padding spec found (if any)
 | ||
|  |     // Return padding.
 | ||
|  |     static details::padding_info handle_padspec_(std::string::const_iterator &it, | ||
|  |                                                  std::string::const_iterator end); | ||
|  | 
 | ||
|  |     void compile_pattern_(const std::string &pattern); | ||
|  | }; | ||
|  | }  // namespace spdlog
 | ||
|  | 
 | ||
|  | #ifdef SPDLOG_HEADER_ONLY
 | ||
|  |     #include "pattern_formatter-inl.h"
 | ||
|  | #endif
 |