如何在 C++ Boost 中使用一个共享配置文件,每个应用程序都有一个接收器

问题描述

我可以轻松创建一个配置文件来将消息发送到控制台、日志文件、DebugView 和事件日志,但我没有找到如何配置它 - 作为共享配置文件 - 应用程序“A”有 4 个不同的接收器部分而不是应用程序“B”。

  1. 这可能吗?
  2. 如何实现? (有链接吗?)

我在主函数中的基本设置如下:

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;
}

亲切的问候, 托马斯

解决方法

  1. 这可能吗?

是的,虽然 Boost.Log 不支持,但开箱即用。

  1. 如何实现? (有链接吗?)

您可以自己实现读取配置文件,也可以重用Boost.Log中的配置文件解析器。例如:

std::ifstream logConfiguration(getCwd() + "\\test-logging.ini");
boost::log::settings unifiedConfig = boost::log::parse_settings(logConfiguration);

此处,settings 是一个容器,其中包含从文件中解析的所有设置(有关文档,请参阅 herehere)。

解析文件后,您必须构建一个过滤的设置容器,该容器对应于每个特定的应用程序。您如何执行此操作取决于统一设置文件格式。例如,如果您的每个应用程序设置都存储在统一配置的单独子部分中,则可以像这样简单:

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...