spdlog/include/spdlog/sinks/sink.h

45 lines
936 B
C
Raw Normal View History

2016-04-20 16:57:49 +08:00
//
// Copyright(c) 2015 Gabi Melman.
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
//
#pragma once
#include "../details/log_msg.h"
2016-04-20 16:57:49 +08:00
2018-03-17 18:47:46 +08:00
namespace spdlog {
namespace sinks {
2016-04-20 16:57:49 +08:00
class sink
{
public:
2018-02-25 06:56:56 +08:00
virtual ~sink() = default;
2018-02-25 09:43:26 +08:00
2018-03-09 21:26:33 +08:00
virtual void log(const details::log_msg &msg) = 0;
2016-04-20 16:57:49 +08:00
virtual void flush() = 0;
bool should_log(level::level_enum msg_level) const;
void set_level(level::level_enum log_level);
level::level_enum level() const;
private:
2018-03-09 21:26:33 +08:00
level_t _level{level::trace};
2016-04-20 16:57:49 +08:00
};
2016-09-15 05:38:21 +08:00
inline bool sink::should_log(level::level_enum msg_level) const
{
return msg_level >= _level.load(std::memory_order_relaxed);
}
2016-09-15 05:38:21 +08:00
inline void sink::set_level(level::level_enum log_level)
{
_level.store(log_level);
}
2016-09-15 05:38:21 +08:00
inline level::level_enum sink::level() const
{
return static_cast<spdlog::level::level_enum>(_level.load(std::memory_order_relaxed));
}
2018-03-17 18:47:46 +08:00
} // namespace sinks
} // namespace spdlog