// Copyright(c) 2015-present, Gabi Melman & spdlog contributors. // Distributed under the MIT License (http://opensource.org/licenses/MIT) #pragma once #include "base_sink.h" #include #include #include #include #include #include #include // Distribution sink (mux). Stores a vector of sinks which get called when log // is called namespace spdlog { namespace sinks { template class dist_sink : public base_sink { public: dist_sink() = default; explicit dist_sink(std::vector> sinks) : sinks_(sinks) {} dist_sink(const dist_sink &) = delete; dist_sink &operator=(const dist_sink &) = delete; void add_sink(std::shared_ptr sink) { std::lock_guard lock(base_sink::mutex_); sinks_.push_back(sink); } void remove_sink(std::shared_ptr sink) { std::lock_guard lock(base_sink::mutex_); sinks_.erase(std::remove(sinks_.begin(), sinks_.end(), sink), sinks_.end()); } void set_sinks(std::vector> sinks) { std::lock_guard lock(base_sink::mutex_); sinks_ = std::move(sinks); } std::vector> &sinks() { return sinks_; } protected: void sink_it_(const details::log_msg &msg) override { for (auto &sub_sink : sinks_) { if (sub_sink->should_log(msg.level)) { sub_sink->log(msg); } } } void flush_() override { for (auto &sub_sink : sinks_) { sub_sink->flush(); } } void set_pattern_(const std::string &pattern) override { set_formatter_(details::make_unique(pattern)); } void set_formatter_(std::unique_ptr sink_formatter) override { base_sink::formatter_ = std::move(sink_formatter); for (auto &sub_sink : sinks_) { sub_sink->set_formatter(base_sink::formatter_->clone()); } } std::vector> sinks_; }; using dist_sink_mt = dist_sink; using dist_sink_st = dist_sink; } // namespace sinks } // namespace spdlog