【发布时间】:2015-09-18 04:53:16
【问题描述】:
我正试图让我的团队离开 log4cxx 并尝试改用 Boost.Log v2。我们现在的log4cxx pattern 比较简单:
log4cxx::helpers::Properties prop;
prop.setProperty("log4j.rootLogger","DEBUG, A1");
prop.setProperty("log4j.appender.A1","org.apache.log4j.ConsoleAppender");
prop.setProperty("log4j.appender.A1.layout","org.apache.log4j.PatternLayout");
prop.setProperty("log4j.appender.A1.layout.ConversionPattern","%d{ABSOLUTE} %-5p [%c] %m%n");
log4cxx::PropertyConfigurator::configure(prop);
但是我找不到支持文件名和行号打印的解决方案。到目前为止,我找到了一个old post,但没有明确的解决方案(没有接受的解决方案)。我已经研究过使用那些BOOST_LOG_NAMED_SCOPE,但它们感觉非常难看,因为当在同一个函数中使用多个这些时,无法打印正确的行号。
我还找到了一个更简单的直接解决方案,here。但这也让人觉得难看,因为它会打印完整路径,而不仅仅是基本名称(它是不可配置的)。所以全路径和行号总是打印在一个固定的位置(expr::smessage之前)。
我还发现了这个post,它看起来像是一个旧的解决方案。
最后,我发现最有希望的解决方案是here。但是它甚至不为我编译。
所以我的问题很简单:如何使用 Boost.Log v2 打印文件名(不是完整路径)和行号最少 formatter flexibility(没有解决方案 MACRO 和 __FILE__ / __LINE__ 接受,请)。我很欣赏不涉及BOOST_LOG_NAMED_SCOPE 的解决方案,如here 所述:
如果您想查看特定日志记录的行号,那么 最好的方法是定义一个自定义宏,您将使用它来编写 日志。在该宏中,您可以将文件名和行号添加为 记录的属性(您可以为此使用操纵器)。笔记 在这种情况下,您将无法在 过滤器,但您可能不需要它。
【问题讨论】:
标签: c++ boost log4cxx boost-log