问题描述:
在chromium项目中进行开发,子项目使用了rsyslog来进行日志读写,项目中有直接依赖的地方会间接依赖chromium的logging模块,具体是在base/logging.h中。rsyslog使用的日志级别LOG_INFO和LOG_WARNING与chromium的logging中定义的日志级别发生了同名冲突。我们在代码的地方,选择使用rsyslog的LOG_INFO而非logging。具体表现为:rsyslog用宏定义,logging用变量。我们在编译项目时始终无法编译通过。总是报如下错误:
expected unqualified-id
原因:
在业务代码中的#include部分,依赖rsyslog的地方是syslog.h,依赖logging的地方是base/logging.h,也就是:
#include<syslog.h>
#include "base/logging.h"
由于syslog.h里面对应的是宏定义,所以在预编译阶段就对对应的位置进行了替换。相当于先进行了宏定义,然后又定义了同名变量,所以编译失败。
解决:
将这两个#include替换一下位置就可以解决:
#include "base/logging.h"
#include<syslog.h>