Эта функциональность встроена в приемник текста, а документация включает пример установки шаблона имени файла и правил поворота при определенных размерах и времени:
// The function registers file sink in the logging library
void init_logging()
{
boost::shared_ptr< logging::core > core = logging::core::get();
boost::shared_ptr< sinks::text_file_backend > backend =
boost::make_shared< sinks::text_file_backend >(
// file name pattern
keywords::file_name = "file_%5N.log",
// rotate the file upon reaching 5 MiB size...
keywords::rotation_size = 5 * 1024 * 1024,
// ...or at noon, whichever comes first
keywords::time_based_rotation = sinks::file::rotation_at_time_point(12, 0, 0)
);
// Wrap it into the frontend and register in the core.
// The backend requires synchronization in the frontend.
typedef sinks::synchronous_sink< sinks::text_file_backend > sink_t;
boost::shared_ptr< sink_t > sink(new sink_t(backend));
core->add_sink(sink);
}
По-видимому, нет способа заставить библиотеку присоединяться к существующим файлам с этой настройкой.Вы должны вызвать backend->scan_for_files();
до создания sink
, как показано под заголовком «Управление повернутыми файлами» в документации, но это только предотвращает перезапись библиотек предыдущими журналами, прежде чем они должны быть очищены.
Когда эта тема возникла в списке рассылки для разработчиков в феврале 2013 года, автор библиотеки объяснил, что добавление поддержки добавления будет нетривиальным изменением , которое нельзя сделать при текущем дизайне.