问题描述
我可以轻松创建一个配置文件来将消息发送到控制台、日志文件、DebugView 和事件日志,但我没有找到如何配置它 - 作为共享配置文件 - 应用程序“A”有 4 个不同的接收器部分而不是应用程序“B”。
- 这可能吗?
- 如何实现? (有链接吗?)
我在主函数中的基本设置如下:
std::ifstream logConfiguration(getCwd() + "\\test-logging.ini");
try {
boost::log::init_from_stream(logConfiguration);
boost::log::add_common_attributes();
boost::log::core::get()->add_global_attribute("Scope",boost::log::attributes::named_scope());
}
catch (std::exception e) {
MYTRACE(error) << e.what() << std::endl;
return 1;
}
亲切的问候, 托马斯
解决方法
- 这可能吗?
是的,虽然 Boost.Log 不支持,但开箱即用。
- 如何实现? (有链接吗?)
您可以自己实现读取配置文件,也可以重用Boost.Log中的配置文件解析器。例如:
std::ifstream logConfiguration(getCwd() + "\\test-logging.ini");
boost::log::settings unifiedConfig = boost::log::parse_settings(logConfiguration);
此处,settings
是一个容器,其中包含从文件中解析的所有设置(有关文档,请参阅 here 和 here)。
解析文件后,您必须构建一个过滤的设置容器,该容器对应于每个特定的应用程序。您如何执行此操作取决于统一设置文件格式。例如,如果您的每个应用程序设置都存储在统一配置的单独子部分中,则可以像这样简单:
boost::property_tree::ptree const& unifiedPtree = unifiedConfig.property_tree();
boost::optional<boost::property_tree::ptree const&> ptreeA =
unifiedPtree.get_child_optional("A");
if (ptreeA) {
// We have some settings for application A
boost::log::settings configA(*ptreeA);
// ...
}
如果您有更复杂的统一配置格式,您可能需要遍历 ptree
节点以过滤掉与不同应用程序相关的设置。有关详细信息,请参阅 Boost.PropertyTree documentation。
最后,当您构建了特定于应用程序的设置容器时,您可以在 Boost.Log 中调用 init_from_settings
:
boost::log::init_from_settings(configA);