Commit b7b421c8 authored by gabi's avatar gabi

Added auto flush to stdout & stderr sinks

parent a7b28285
...@@ -39,7 +39,7 @@ template<class Mutex> ...@@ -39,7 +39,7 @@ template<class Mutex>
class ostream_sink: public base_sink<Mutex> class ostream_sink: public base_sink<Mutex>
{ {
public: public:
explicit ostream_sink(std::ostream& os) :_ostream(os) {} explicit ostream_sink(std::ostream& os, bool force_flush=false) :_ostream(os), _force_flush(force_flush) {}
ostream_sink(const ostream_sink&) = delete; ostream_sink(const ostream_sink&) = delete;
ostream_sink& operator=(const ostream_sink&) = delete; ostream_sink& operator=(const ostream_sink&) = delete;
virtual ~ostream_sink() = default; virtual ~ostream_sink() = default;
...@@ -48,8 +48,11 @@ protected: ...@@ -48,8 +48,11 @@ protected:
virtual void _sink_it(const details::log_msg& msg) override virtual void _sink_it(const details::log_msg& msg) override
{ {
_ostream.write(msg.formatted.data(), msg.formatted.size()); _ostream.write(msg.formatted.data(), msg.formatted.size());
if (_force_flush)
_ostream.flush();
} }
std::ostream& _ostream; std::ostream& _ostream;
bool _force_flush;
}; };
typedef ostream_sink<std::mutex> ostream_sink_mt; typedef ostream_sink<std::mutex> ostream_sink_mt;
......
...@@ -38,7 +38,7 @@ template <class Mutex> ...@@ -38,7 +38,7 @@ template <class Mutex>
class stdout_sink : public ostream_sink<Mutex> class stdout_sink : public ostream_sink<Mutex>
{ {
public: public:
stdout_sink() : ostream_sink<Mutex>(std::cout) {} stdout_sink() : ostream_sink<Mutex>(std::cout, true) {}
}; };
...@@ -50,7 +50,7 @@ template <class Mutex> ...@@ -50,7 +50,7 @@ template <class Mutex>
class stderr_sink : public ostream_sink<Mutex> class stderr_sink : public ostream_sink<Mutex>
{ {
public: public:
stderr_sink() : ostream_sink<Mutex>(std::cerr) {} stderr_sink() : ostream_sink<Mutex>(std::cerr, true) {}
}; };
typedef stderr_sink<std::mutex> stderr_sink_mt; typedef stderr_sink<std::mutex> stderr_sink_mt;
......
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