1818#include < spdlog/details/registry.h>
1919#include < spdlog/details/thread_pool.h>
2020
21+ #include < functional>
2122#include < memory>
2223#include < mutex>
23- #include < functional>
2424
2525namespace spdlog {
2626
@@ -31,27 +31,25 @@ static const size_t default_async_q_size = 8192;
3131// async logger factory - creates async loggers backed with thread pool.
3232// if a global thread pool doesn't already exist, create it with default queue
3333// size of 8192 items and single thread.
34- template <async_overflow_policy OverflowPolicy = async_overflow_policy::block>
35- struct async_factory_impl
36- {
37- template <typename Sink, typename ... SinkArgs>
38- static std::shared_ptr<async_logger> create (std::string logger_name, SinkArgs &&...args)
39- {
34+ template <async_overflow_policy OverflowPolicy = async_overflow_policy::block>
35+ struct async_factory_impl {
36+ template <typename Sink, typename ... SinkArgs>
37+ static std::shared_ptr<async_logger> create (std::string logger_name, SinkArgs &&...args) {
4038 auto ®istry_inst = details::registry::instance ();
4139
4240 // create global thread pool if not already exists..
4341
4442 auto &mutex = registry_inst.tp_mutex ();
4543 std::lock_guard<std::recursive_mutex> tp_lock (mutex);
4644 auto tp = registry_inst.get_tp ();
47- if (tp == nullptr )
48- {
45+ if (tp == nullptr ) {
4946 tp = std::make_shared<details::thread_pool>(details::default_async_q_size, 1U );
5047 registry_inst.set_tp (tp);
5148 }
5249
5350 auto sink = std::make_shared<Sink>(std::forward<SinkArgs>(args)...);
54- auto new_logger = std::make_shared<async_logger>(std::move (logger_name), std::move (sink), std::move (tp), OverflowPolicy);
51+ auto new_logger = std::make_shared<async_logger>(std::move (logger_name), std::move (sink),
52+ std::move (tp), OverflowPolicy);
5553 registry_inst.initialize_logger (new_logger);
5654 return new_logger;
5755 }
@@ -60,40 +58,42 @@ struct async_factory_impl
6058using async_factory = async_factory_impl<async_overflow_policy::block>;
6159using async_factory_nonblock = async_factory_impl<async_overflow_policy::overrun_oldest>;
6260
63- template <typename Sink, typename ... SinkArgs>
64- inline std::shared_ptr<spdlog::logger> create_async (std::string logger_name, SinkArgs &&...sink_args)
65- {
66- return async_factory::create<Sink>(std::move (logger_name), std::forward<SinkArgs>(sink_args)...);
61+ template <typename Sink, typename ... SinkArgs>
62+ inline std::shared_ptr<spdlog::logger> create_async (std::string logger_name,
63+ SinkArgs &&...sink_args) {
64+ return async_factory::create<Sink>(std::move (logger_name),
65+ std::forward<SinkArgs>(sink_args)...);
6766}
6867
69- template <typename Sink, typename ... SinkArgs>
70- inline std::shared_ptr<spdlog::logger> create_async_nb (std::string logger_name, SinkArgs &&...sink_args)
71- {
72- return async_factory_nonblock::create<Sink>(std::move (logger_name), std::forward<SinkArgs>(sink_args)...);
68+ template <typename Sink, typename ... SinkArgs>
69+ inline std::shared_ptr<spdlog::logger> create_async_nb (std::string logger_name,
70+ SinkArgs &&...sink_args) {
71+ return async_factory_nonblock::create<Sink>(std::move (logger_name),
72+ std::forward<SinkArgs>(sink_args)...);
7373}
7474
7575// set global thread pool.
76- inline void init_thread_pool (
77- size_t q_size, size_t thread_count, std::function<void ()> on_thread_start, std::function<void()> on_thread_stop)
78- {
79- auto tp = std::make_shared<details::thread_pool>(q_size, thread_count, on_thread_start, on_thread_stop);
76+ inline void init_thread_pool (size_t q_size,
77+ size_t thread_count,
78+ std::function<void ()> on_thread_start,
79+ std::function<void()> on_thread_stop) {
80+ auto tp = std::make_shared<details::thread_pool>(q_size, thread_count, on_thread_start,
81+ on_thread_stop);
8082 details::registry::instance ().set_tp (std::move (tp));
8183}
8284
83- inline void init_thread_pool (size_t q_size, size_t thread_count, std::function<void ()> on_thread_start)
84- {
85+ inline void init_thread_pool (size_t q_size,
86+ size_t thread_count,
87+ std::function<void ()> on_thread_start) {
8588 init_thread_pool (q_size, thread_count, on_thread_start, [] {});
8689}
8790
88- inline void init_thread_pool (size_t q_size, size_t thread_count)
89- {
90- init_thread_pool (
91- q_size, thread_count, [] {}, [] {});
91+ inline void init_thread_pool (size_t q_size, size_t thread_count) {
92+ init_thread_pool (q_size, thread_count, [] {}, [] {});
9293}
9394
9495// get the global thread pool.
95- inline std::shared_ptr<spdlog::details::thread_pool> thread_pool ()
96- {
96+ inline std::shared_ptr<spdlog::details::thread_pool> thread_pool () {
9797 return details::registry::instance ().get_tp ();
9898}
99- } // namespace spdlog
99+ } // namespace spdlog
0 commit comments