diff options
author | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2018-07-09 14:11:07 +0200 |
---|---|---|
committer | Jörg Frings-Fürst <debian@jff-webhosting.net> | 2018-07-09 14:11:07 +0200 |
commit | 9033aee6c281674e5d3d64e2f07bd8f7e7bbe694 (patch) | |
tree | a8748b55127d6be88e4b71b1dddf5985daac6a94 /lib/spdlog/sinks/ostream_sink.h | |
parent | b84c8622d092fd773888eed89f1dbffb2c3a57f7 (diff) | |
parent | cb4fdfae7c68f6f4eef5893769f4b885bcb48186 (diff) |
Merge branch 'feature/upstream' into develop
Diffstat (limited to 'lib/spdlog/sinks/ostream_sink.h')
-rw-r--r-- | lib/spdlog/sinks/ostream_sink.h | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/lib/spdlog/sinks/ostream_sink.h b/lib/spdlog/sinks/ostream_sink.h new file mode 100644 index 0000000..9728138 --- /dev/null +++ b/lib/spdlog/sinks/ostream_sink.h @@ -0,0 +1,49 @@ +// +// Copyright(c) 2015 Gabi Melman. +// Distributed under the MIT License (http://opensource.org/licenses/MIT) +// + +#pragma once + +#include "../details/null_mutex.h" +#include "base_sink.h" + +#include <mutex> +#include <ostream> + +namespace spdlog { +namespace sinks { +template<class Mutex> +class ostream_sink : public base_sink<Mutex> +{ +public: + 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; + +protected: + void _sink_it(const details::log_msg &msg) override + { + _ostream.write(msg.formatted.data(), msg.formatted.size()); + if (_force_flush) + _ostream.flush(); + } + + void _flush() override + { + _ostream.flush(); + } + + std::ostream &_ostream; + bool _force_flush; +}; + +using ostream_sink_mt = ostream_sink<std::mutex>; +using ostream_sink_st = ostream_sink<details::null_mutex>; + +} // namespace sinks +} // namespace spdlog |