Передача объекта functon в качестве фильтра при инициализации приемника лога буста - PullRequest
0 голосов
/ 21 января 2019

Я создаю новый приемник, как в этом примере:

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

Но я пока не могу понять, каким должно быть это "ЧТО-ТО".Не могу найти никаких примеров.Можете ли вы помочь мне?

1 Ответ

0 голосов
/ 23 января 2019

Во-первых, keywords::format используется для передачи форматера, а не фильтра. Для фильтров используйте keywords::filter ключевое слово параметра.

Во-вторых, оба ключевых слова keywords::format и keywords::filter в настоящее время поддерживают только строковые аргументы. Принятые строки интерпретируются в соответствии с синтаксисом, описанным здесь как форматтер или фильтр соответственно.

Если вы хотите установить объект функции в качестве фильтра, вам следует вызвать set_filter в созданном приемнике вместе с вашим объектом функции. add_file_log возвращает указатель на созданный приемник, поэтому вы можете сделать это следующим образом:

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

То же самое относится и к формататору; приемники форматирования предоставляют set_formatter метод для этого.

...