90 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
		
		
			
		
	
	
			90 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
|  | // Copyright(c) 2015-present, Gabi Melman & spdlog contributors.
 | ||
|  | // Distributed under the MIT License (http://opensource.org/licenses/MIT)
 | ||
|  | 
 | ||
|  | #pragma once
 | ||
|  | 
 | ||
|  | #include <spdlog/details/file_helper.h>
 | ||
|  | #include <spdlog/details/null_mutex.h>
 | ||
|  | #include <spdlog/details/synchronous_factory.h>
 | ||
|  | #include <spdlog/sinks/base_sink.h>
 | ||
|  | 
 | ||
|  | #include <chrono>
 | ||
|  | #include <mutex>
 | ||
|  | #include <string>
 | ||
|  | 
 | ||
|  | namespace spdlog { | ||
|  | namespace sinks { | ||
|  | 
 | ||
|  | //
 | ||
|  | // Rotating file sink based on size
 | ||
|  | //
 | ||
|  | template <typename Mutex> | ||
|  | class rotating_file_sink final : public base_sink<Mutex> { | ||
|  | public: | ||
|  |     rotating_file_sink(filename_t base_filename, | ||
|  |                        std::size_t max_size, | ||
|  |                        std::size_t max_files, | ||
|  |                        bool rotate_on_open = false, | ||
|  |                        const file_event_handlers &event_handlers = {}); | ||
|  |     static filename_t calc_filename(const filename_t &filename, std::size_t index); | ||
|  |     filename_t filename(); | ||
|  | 
 | ||
|  | protected: | ||
|  |     void sink_it_(const details::log_msg &msg) override; | ||
|  |     void flush_() override; | ||
|  | 
 | ||
|  | private: | ||
|  |     // Rotate files:
 | ||
|  |     // log.txt -> log.1.txt
 | ||
|  |     // log.1.txt -> log.2.txt
 | ||
|  |     // log.2.txt -> log.3.txt
 | ||
|  |     // log.3.txt -> delete
 | ||
|  |     void rotate_(); | ||
|  | 
 | ||
|  |     // delete the target if exists, and rename the src file  to target
 | ||
|  |     // return true on success, false otherwise.
 | ||
|  |     bool rename_file_(const filename_t &src_filename, const filename_t &target_filename); | ||
|  | 
 | ||
|  |     filename_t base_filename_; | ||
|  |     std::size_t max_size_; | ||
|  |     std::size_t max_files_; | ||
|  |     std::size_t current_size_; | ||
|  |     details::file_helper file_helper_; | ||
|  | }; | ||
|  | 
 | ||
|  | using rotating_file_sink_mt = rotating_file_sink<std::mutex>; | ||
|  | using rotating_file_sink_st = rotating_file_sink<details::null_mutex>; | ||
|  | 
 | ||
|  | }  // namespace sinks
 | ||
|  | 
 | ||
|  | //
 | ||
|  | // factory functions
 | ||
|  | //
 | ||
|  | 
 | ||
|  | template <typename Factory = spdlog::synchronous_factory> | ||
|  | inline std::shared_ptr<logger> rotating_logger_mt(const std::string &logger_name, | ||
|  |                                                   const filename_t &filename, | ||
|  |                                                   size_t max_file_size, | ||
|  |                                                   size_t max_files, | ||
|  |                                                   bool rotate_on_open = false, | ||
|  |                                                   const file_event_handlers &event_handlers = {}) { | ||
|  |     return Factory::template create<sinks::rotating_file_sink_mt>( | ||
|  |         logger_name, filename, max_file_size, max_files, rotate_on_open, event_handlers); | ||
|  | } | ||
|  | 
 | ||
|  | template <typename Factory = spdlog::synchronous_factory> | ||
|  | inline std::shared_ptr<logger> rotating_logger_st(const std::string &logger_name, | ||
|  |                                                   const filename_t &filename, | ||
|  |                                                   size_t max_file_size, | ||
|  |                                                   size_t max_files, | ||
|  |                                                   bool rotate_on_open = false, | ||
|  |                                                   const file_event_handlers &event_handlers = {}) { | ||
|  |     return Factory::template create<sinks::rotating_file_sink_st>( | ||
|  |         logger_name, filename, max_file_size, max_files, rotate_on_open, event_handlers); | ||
|  | } | ||
|  | }  // namespace spdlog
 | ||
|  | 
 | ||
|  | #ifdef SPDLOG_HEADER_ONLY
 | ||
|  |     #include "rotating_file_sink-inl.h"
 | ||
|  | #endif
 |