chromium log macro
logging.cc
里面有min_log_level,minimal log level,可以设置或者获取这个level,SetMinLogLevel,GetMinLogLevel。(c++的## 处理器,会忽略空格)在实现中SetMinLogLevel,最小的level,取std::min(LOG_FATAL, level);
const LogSeverity LOG_INFO = 0;
const LogSeverity LOG_WARNING = 1;
const LogSeverity LOG_ERROR = 2;
const LogSeverity LOG_FATAL = 3;
const LogSeverity LOG_NUM_SEVERITIES = 4;
#define LAZY_STREAM(stream, condition) \
!(condition) ? (void) 0 : ::logging::LogMessageVoidify() & (stream)
一个辅助宏,如果条件不存在,就不初始化流。
打印log的宏如下,这个log最终返回一个stream流
#define LOG(severity) LAZY_STREAM(LOG_STREAM(severity), LOG_IS_ON(severity))
而#define LOG_STREAM(severity) COMPACT_GOOGLE_LOG_ ## severity.stream()
COMPACT_GOOGLE_LOG_severity.stream 是定义好的stream(里面实现有些饶)
LOG(INFO) << "Found " << num_cookies的最终结果就是:
!(((::logging::LOG_INFO) >= 1))) ? (void) 0 : ::logging::LogMessageVoidify() & (logging::LogMessage("a.c", 99, logging::LOG_INFO).stream()) << "Found " << num_cookies;