diff options
author | Benety Goh <benety@mongodb.com> | 2014-06-10 18:50:40 -0400 |
---|---|---|
committer | Benety Goh <benety@mongodb.com> | 2014-06-26 19:41:32 -0400 |
commit | 4d00dd9723f84f197afffd901101276916d1ee6c (patch) | |
tree | 1d57039912b23cf3132a10faca60934dbdb463cb /src/mongo/util/log.h | |
parent | e1dca2cdeed7cf5549a85d487def752d600af244 (diff) | |
download | mongo-4d00dd9723f84f197afffd901101276916d1ee6c.tar.gz |
SERVER-5092 support log tags for LOG() messages
Diffstat (limited to 'src/mongo/util/log.h')
-rw-r--r-- | src/mongo/util/log.h | 37 |
1 files changed, 36 insertions, 1 deletions
diff --git a/src/mongo/util/log.h b/src/mongo/util/log.h index ab221bd01da..a98b9b161f5 100644 --- a/src/mongo/util/log.h +++ b/src/mongo/util/log.h @@ -31,6 +31,7 @@ #include "mongo/base/status.h" #include "mongo/bson/util/builder.h" +#include "mongo/logger/log_tag.h" #include "mongo/logger/logger.h" #include "mongo/logger/logstream_builder.h" #include "mongo/logger/tee.h" @@ -85,12 +86,25 @@ namespace logger { } +// MONGO_LOG uses log tag from MongoLogDefaultTag from current or global namespace. #define MONGO_LOG(DLEVEL) \ - if (!(::mongo::logger::globalLogDomain())->shouldLog(::mongo::LogstreamBuilder::severityCast(DLEVEL))) {} \ + if (!(::mongo::logger::globalLogDomain())->shouldLog(MongoLogDefaultTag_tag, ::mongo::LogstreamBuilder::severityCast(DLEVEL))) {} \ else LogstreamBuilder(::mongo::logger::globalLogDomain(), getThreadName(), ::mongo::LogstreamBuilder::severityCast(DLEVEL)) #define LOG MONGO_LOG +#define MONGO_LOG_TAG(DLEVEL, TAG1) \ + if (!(::mongo::logger::globalLogDomain())->shouldLog((TAG1), ::mongo::LogstreamBuilder::severityCast(DLEVEL))) {} \ + else LogstreamBuilder(::mongo::logger::globalLogDomain(), getThreadName(), ::mongo::LogstreamBuilder::severityCast(DLEVEL)) + +#define MONGO_LOG_TAG2(DLEVEL, TAG1, TAG2) \ + if (!(::mongo::logger::globalLogDomain())->shouldLog((TAG1), (TAG2), ::mongo::LogstreamBuilder::severityCast(DLEVEL))) {} \ + else LogstreamBuilder(::mongo::logger::globalLogDomain(), getThreadName(), ::mongo::LogstreamBuilder::severityCast(DLEVEL)) + +#define MONGO_LOG_TAG3(DLEVEL, TAG1, TAG2, TAG3) \ + if (!(::mongo::logger::globalLogDomain())->shouldLog((TAG1), (TAG2), (TAG3), ::mongo::LogstreamBuilder::severityCast(DLEVEL))) {} \ + else LogstreamBuilder(::mongo::logger::globalLogDomain(), getThreadName(), ::mongo::LogstreamBuilder::severityCast(DLEVEL)) + /** * Rotates the log files. Returns true if all logs rotate successfully. * @@ -127,3 +141,24 @@ namespace logger { void logContext(const char *msg = NULL); } // namespace mongo + +/** + * Defines default log tag for MONGO_LOG. + * Use this macro inside an implementation namespace or code block where debug messages + * are logged using MONGO_LOG(). + * + * Note: Do not use more than once inside any namespace/code block. + * Using static function instead of enum to support use inside function code block. + */ +#define MONGO_LOG_DEFAULT_TAG_FILE(TAG) \ + static const ::mongo::logger::LogTag MongoLogDefaultTag_tag = (TAG); + +/** + * MONGO_LOG_DEFAULT_TAG for local code block. + */ +#define MONGO_LOG_DEFAULT_TAG_LOCAL(TAG) \ + const ::mongo::logger::LogTag MongoLogDefaultTag_tag = (TAG); + +// Provide log tag in global scope so that MONGO_LOG will always have +// a valid tag. +const ::mongo::logger::LogTag MongoLogDefaultTag_tag = ::mongo::logger::LogTag::kDefault; |