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
|
|
|
|
|
2017-11-11 20:44:27 +08:00
|
|
|
#include "../details/log_msg.h"
|
2016-04-20 16:57:49 +08:00
|
|
|
|
|
|
|
namespace spdlog
|
|
|
|
{
|
|
|
|
namespace sinks
|
|
|
|
{
|
|
|
|
class sink
|
|
|
|
{
|
|
|
|
public:
|
2018-02-25 06:56:56 +08:00
|
|
|
virtual ~sink() = default;
|
2018-02-25 09:43:26 +08:00
|
|
|
|
2016-04-20 16:57:49 +08:00
|
|
|
virtual void log(const details::log_msg& msg) = 0;
|
|
|
|
virtual void flush() = 0;
|
2016-09-13 04:26:38 +08:00
|
|
|
|
|
|
|
bool should_log(level::level_enum msg_level) const;
|
|
|
|
void set_level(level::level_enum log_level);
|
|
|
|
level::level_enum level() const;
|
|
|
|
|
|
|
|
private:
|
2018-02-25 07:31:14 +08:00
|
|
|
level_t _level{ level::trace };
|
2016-04-20 16:57:49 +08:00
|
|
|
};
|
2016-09-13 04:26:38 +08:00
|
|
|
|
2016-09-15 05:38:21 +08:00
|
|
|
inline bool sink::should_log(level::level_enum msg_level) const
|
|
|
|
{
|
2016-09-13 04:26:38 +08:00
|
|
|
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)
|
|
|
|
{
|
2016-09-13 04:26:38 +08:00
|
|
|
_level.store(log_level);
|
|
|
|
}
|
|
|
|
|
2016-09-15 05:38:21 +08:00
|
|
|
inline level::level_enum sink::level() const
|
|
|
|
{
|
2016-09-13 04:26:38 +08:00
|
|
|
return static_cast<spdlog::level::level_enum>(_level.load(std::memory_order_relaxed));
|
|
|
|
}
|
|
|
|
|
2016-04-20 16:57:49 +08:00
|
|
|
}
|
|
|
|
}
|