我正在创建新的接收器,如下例所示:
void init()
{
logging::add_file_log
(
keywords::file_name = "sample_%N.log",
keywords::rotation_size = 10 * 1024 * 1024,
keywords::time_based_rotation = sinks::file::rotation_at_time_point(0, 0, 0),
keywords::format = "[%TimeStamp%]: %Message%"
);
logging::core::get()->set_filter
(
logging::trivial::severity >= logging::trivial::info
);
}
我已经实现了自己的过滤器对象:
struct MyFilter {
...
bool operator()(const boost::log::attribute_value_set& attrs) const noexcept
{
bool result = ....
// Do my filtering
return result;
}
...
};
如何将其作为接收器初始化参数传递? 即我想添加以下参数:
keywords::filter = SOMETHING(MyFilter())
但是到目前为止,我还无法弄清楚“ SOMETHING”应该是什么。找不到任何示例。你能帮我吗?
答案 0 :(得分:1)
首先,keywords::format
用于传递格式化程序,而不是过滤器。对于过滤器,请使用keywords::filter
参数关键字。
第二,keywords::format
和keywords::filter
关键字当前仅支持字符串参数。根据{{3}}所描述的语法,将接受的字符串分别解释为格式器或过滤器。
如果要将功能对象设置为过滤器,则应使用功能对象在创建的接收器上调用set_filter
。 add_file_log
返回一个指向创建的接收器的指针,因此您可以这样操作:
auto sink = logging::add_file_log(...);
sink->set_filter(MyFilter());
格式化程序也是如此;格式化接收器为此提供了set_formatter
方法。