Skip to content

Commit

Permalink
Added auto flush to stdout & stderr sinks
Browse files Browse the repository at this point in the history
  • Loading branch information
Gabi120 committed Jan 28, 2015
1 parent a7b2828 commit b7b421c
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 3 deletions.
5 changes: 4 additions & 1 deletion include/spdlog/sinks/ostream_sink.h
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ template<class Mutex>
class ostream_sink: public base_sink<Mutex>
{
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& operator=(const ostream_sink&) = delete;
virtual ~ostream_sink() = default;
Expand All @@ -48,8 +48,11 @@ class ostream_sink: public base_sink<Mutex>
virtual void _sink_it(const details::log_msg& msg) override
{
_ostream.write(msg.formatted.data(), msg.formatted.size());
if (_force_flush)
_ostream.flush();
}
std::ostream& _ostream;
bool _force_flush;
};

typedef ostream_sink<std::mutex> ostream_sink_mt;
Expand Down
4 changes: 2 additions & 2 deletions include/spdlog/sinks/stdout_sinks.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ template <class Mutex>
class stdout_sink : public ostream_sink<Mutex>
{
public:
stdout_sink() : ostream_sink<Mutex>(std::cout) {}
stdout_sink() : ostream_sink<Mutex>(std::cout, true) {}

};

Expand All @@ -50,7 +50,7 @@ template <class Mutex>
class stderr_sink : public ostream_sink<Mutex>
{
public:
stderr_sink() : ostream_sink<Mutex>(std::cerr) {}
stderr_sink() : ostream_sink<Mutex>(std::cerr, true) {}
};

typedef stderr_sink<std::mutex> stderr_sink_mt;
Expand Down

0 comments on commit b7b421c

Please sign in to comment.