Commit aa0f6229 authored by gabime's avatar gabime

fixed dist_sink in gcc

parent 916a686f
...@@ -11,6 +11,7 @@ ...@@ -11,6 +11,7 @@
#include <spdlog/sinks/sink.h> #include <spdlog/sinks/sink.h>
#include <algorithm> #include <algorithm>
#include <mutex>
#include <memory> #include <memory>
#include <vector> #include <vector>
...@@ -23,7 +24,7 @@ namespace sinks ...@@ -23,7 +24,7 @@ namespace sinks
template<class Mutex> template<class Mutex>
class dist_sink: public base_sink<Mutex> class dist_sink: public base_sink<Mutex>
{ {
public: public:
explicit dist_sink() :_sinks() {} explicit dist_sink() :_sinks() {}
dist_sink(const dist_sink&) = delete; dist_sink(const dist_sink&) = delete;
dist_sink& operator=(const dist_sink&) = delete; dist_sink& operator=(const dist_sink&) = delete;
...@@ -42,20 +43,20 @@ protected: ...@@ -42,20 +43,20 @@ protected:
public: public:
void flush() override void flush() override
{ {
std::lock_guard<Mutex> lock(_mutex); std::lock_guard<Mutex> lock(base_sink<Mutex>::_mutex);
for (auto &sink : _sinks) for (auto &sink : _sinks)
sink->flush(); sink->flush();
} }
void add_sink(std::shared_ptr<sink> sink) void add_sink(std::shared_ptr<sink> sink)
{ {
std::lock_guard<Mutex> lock(_mutex); std::lock_guard<Mutex> lock(base_sink<Mutex>::_mutex);
_sinks.push_back(sink); _sinks.push_back(sink);
} }
void remove_sink(std::shared_ptr<sink> sink) void remove_sink(std::shared_ptr<sink> sink)
{ {
std::lock_guard<Mutex> lock(_mutex); std::lock_guard<Mutex> lock(base_sink<Mutex>::_mutex);
_sinks.erase(std::remove(_sinks.begin(), _sinks.end(), sink), _sinks.end()); _sinks.erase(std::remove(_sinks.begin(), _sinks.end(), sink), _sinks.end());
} }
}; };
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment