7

我正在尝试让 Boost.Log 进入我的项目。问题来自简单示例的以下行:

using namespace boost::log;
core::get()->set_filter
(
    trivial::severity >= trivial::info
);

在我的代码中,这转换为以下内容:

boost::log::core::get()->set_filter(
  boost::log::trivial::severity >= boost::log::trivial::info
);

但是,我收到以下错误:

error C2039: 'severity' : is not a member of 'boost::log::v2s_mt_nt5::trivial'
error C2065: 'severity' : undeclared identifier

我正在搜索命名空间,试图找出我应该如何做到这一点,但我并没有真正找到任何有用的东西。这似乎需要一些疯狂的 lambda 函数。我可以选择一些替代方案(定义一个填充过滤级别的函数?),但我不确定如何实现这一点。有任何想法吗?

我正在使用 Boost.Log 版本 2.0-r862 和 Boost 1.53.0。

解决方案:Ryan 指出我应该检查我的包含,果然我只是包含trivial.hpp,但core.hppexpressions.hpp需要作为包含。包括他们解决了这个问题。

// need at least these 3 to get "trivial" to work
#include <boost/log/core.hpp>
#include <boost/log/expressions.hpp>
#include <boost/log/trivial.hpp>
4

2 回答 2

2

看着trivial.hpp,它似乎severitykeywords命名空间的一部分。你试过了boost::log::keywords::severity吗?

于 2013-05-01T19:48:30.583 回答
0

这是 C++11 中的完整工作示例,总结了@aardvarkk 解决方案:

#include <boost/log/expressions.hpp>
#include <boost/log/core.hpp>
#include <boost/log/trivial.hpp>

namespace logging = boost::log;

auto init() -> void
{
    logging::core::get()->set_filter
    (
        logging::trivial::severity >= logging::trivial::warning
    );
}

auto main(int argn, char *args[]) -> int
{
    init();

    BOOST_LOG_TRIVIAL(info) << "Testing the log system";
    BOOST_LOG_TRIVIAL(error) << "Testing the log error";


    return 0;
}
于 2015-03-03T08:46:10.577 回答