C ++如何在Boost Global Logger上设置严重性过滤器

时间:2015-04-21 23:53:48

标签: c++ logging boost

我已经尝试了几天来创建一个Boost Global Logger以便在整个应用程序中使用但我似乎无法在Global Logger中设置严重性级别

重要:

请看下面安德烈的回答......它被标记为步骤(a)和(b)但我仍然没有做到这一点!


直接提升文档here

  

...拥有一个或多个全局记录器会更方便   为了在需要时在每个地方轻松访问它们。在这方面   std :: cout就是这种记录器的一个很好的例子。

     

该库提供了一种声明全局记录器的方法   访问非常像std :: cout。实际上,可以使用此功能   任何记录器,包括用户定义的记录器。宣布全球化   记录器,可以确保对此记录器具有线程安全访问权限   来自应用程序代码的任何位置的实例。图书馆也   保证全局记录器实例在整个过程中都是唯一的   模块边界。这允许甚至仅在标题中使用日志记录   可能被编译到不同模块的组件。

     
     

无论您用于声明记录器的宏如何,都可以   使用记录器的静态get函数获取记录器实例   标记:

src::severity_logger_mt< >& lg = my_logger::get();

我从Boost Logger大师安德烈发现,我的问题是严重性类型不匹配

  

您已使用默认模板实例化severity_logger_mt   参数,因此严重性级别属性的类型为int。你的枚举   值转换为int并发送到日志记录核心。你还没有   设置任何接收器,因此默认情况下使用默认接收器。水槽   尝试从日志记录中提取严重性级别属性值,   但是没有这样做,因为它期望严重性级别为   类型boost :: log :: trivial :: severity_level。在那次失败之后   回落到boost :: log :: trivial :: severity_level :: info severity。

     

如果您想将枚举用于严重性级别,则必须:

------------------------------------(现在,这是答案! !!!)---------------------------------------

  

(a)在记录器模板参数和

中指定它      

(b)使用了解您的枚举的格式化程序设置接收器。

但我无法弄清楚如何做到这一点,因为即使在尝试遵循他的指示之后,严重性级别看起来像接收器仍然会回落到boost :: log :: trivial :: severity_level :: info severity 。任何人都可以帮我弄清楚如何在我的全局记录器中正确设置严重性?这是代码:

标题

#include <boost/log/trivial.hpp>
#include <boost/log/sources/global_logger_storage.hpp>

enum severity_level
{
    normal,
    warning,
    error,
    critical
};

BOOST_LOG_GLOBAL_LOGGER(logger, boost::log::sources::severity_logger_mt< severity_level >)

CPP

#include "GlobalLogger.h"

#include <boost/log/expressions/formatters/date_time.hpp>
#include <boost/log/expressions.hpp>
#include <boost/log/sinks/sync_frontend.hpp>
#include <boost/log/sinks/text_ostream_backend.hpp>
#include <boost/log/support/date_time.hpp>
#include <boost/core/null_deleter.hpp>
#include <boost/log/utility/setup/common_attributes.hpp>
#include <boost/make_shared.hpp>
#include <boost/log/utility/setup/file.hpp>
#include <boost/log/utility/setup/console.hpp>
#include <boost/log/sinks.hpp>
#include <fstream>

namespace logging = boost::log;
namespace src = boost::log::sources;
namespace expr = boost::log::expressions;
namespace sinks = boost::log::sinks;
namespace attrs = boost::log::attributes;

bool onlyWarnings(const boost::log::attribute_value_set& set)
{
    return set["Severity"].extract<severity_level>() > 0;
}

void severity_and_message(const boost::log::record_view &view, boost::log::formatting_ostream &os)
{
    os << view.attribute_values()["Severity"].extract<severity_level>() << ": " <<
    view.attribute_values()["Message"].extract<std::string>();
}

BOOST_LOG_GLOBAL_LOGGER_INIT(logger, boost::log::sources::severity_logger_mt< severity_level >)
{
    boost::log::sources::severity_logger_mt< severity_level > logger;

    // add a text sink
    typedef sinks::asynchronous_sink<sinks::text_ostream_backend> text_sink;
    boost::shared_ptr<text_sink> sink = boost::make_shared<text_sink>();

    // add "console" output stream to our sink
    boost::shared_ptr<std::ostream> stream{&std::clog, boost::null_deleter{}};
    sink->locked_backend()->add_stream(stream);

    // specify the format of the log message
    sink->set_formatter(&severity_and_message);

    // just log messages with severity >= SEVERITY_THRESHOLD are written
    sink->set_filter(&onlyWarnings);

    // "register" our sink
    logging::core::get()->add_sink(sink);

    logging::add_common_attributes();

    return logger;
}

的main.cpp

#include <iostream>

#include "GlobalLogger.h"

using namespace std;

int main() {
    boost::log::sources::severity_logger_mt<  severity_level >& lg = logger::get();
    BOOST_LOG_SEV(lg, severity_level::normal) << "note";
    BOOST_LOG_SEV(lg, severity_level::warning) << "warning";
    BOOST_LOG_SEV(lg, severity_level::critical) << "critical";

    return 0;
}

我在62.10. A macro to define a global logger找到了一个更好的示例this SO question和一个工作版本。但是工作示例不使用get()方法。因此,在声明BOOST_LOG_GLOBAL_LOGGER之后,我能够访问log :: get()但我仍然无法识别其严重性

1 个答案:

答案 0 :(得分:5)

我找到了促进日志专家安德烈。为了帮助将来的其他人,我发布了一个指向我们Sourceforge discussion的链接。在我的显示器上敲了很多头之后,他接受了解释并重新审视this SO question中的工作版本。但我终于搞定了! YAY !!!