0

我正在创建新的接收器,如下例所示:

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())

但到目前为止,我无法弄清楚“某事”应该是什么。找不到任何例子。你能帮我么?

4

1 回答 1

2

首先,keywords::format用于传递格式化程序,而不是过滤器。对于过滤器,使用keywords::filter参数关键字。

其次,keywords::formatkeywords::filter关键字目前仅支持字符串参数。接受的字符串根据此处描述的语法分别解释为格式化程序或过滤器。

如果要将函数对象设置为过滤器,则应set_filter使用函数对象调用创建的接收器。add_file_log返回一个指向创建的接收器的指针,所以你可以这样做:

auto sink = logging::add_file_log(...);
sink->set_filter(MyFilter());

这同样适用于格式化程序;格式化接收器为此提供set_formatter了方法。

于 2019-01-23T08:43:19.370 回答