Commit 027332ff authored by Yoshisato Yanagisawa's avatar Yoshisato Yanagisawa

DCHECK_ALWAYS_ON to make D* enabled under NDEBUG

The macro NDEBUG could be automatically defined for release build on
some build environments (e.g. MSVC).  If we use NDEBUG as a key to
distinguish using DCHECK as CHECK (I call this DCHECK is enabled) or
not, we cannot make DCHECK enabled for release build on such
environments.

Considering people use a program with glog for presubmit testing or
dogfooding, they should need to do release build with DCHECK enabled.
parent b6a5e052
...@@ -431,9 +431,15 @@ DECLARE_bool(stop_logging_if_full_disk); ...@@ -431,9 +431,15 @@ DECLARE_bool(stop_logging_if_full_disk);
#define LOG_TO_STRING_FATAL(message) @ac_google_namespace@::NullStreamFatal() #define LOG_TO_STRING_FATAL(message) @ac_google_namespace@::NullStreamFatal()
#endif #endif
#if defined(NDEBUG) && !defined(DCHECK_ALWAYS_ON)
#define DCHECK_IS_ON() 0
#else
#define DCHECK_IS_ON() 1
#endif
// For DFATAL, we want to use LogMessage (as opposed to // For DFATAL, we want to use LogMessage (as opposed to
// LogMessageFatal), to be consistent with the original behavior. // LogMessageFatal), to be consistent with the original behavior.
#ifdef NDEBUG #if !DCHECK_IS_ON()
#define COMPACT_GOOGLE_LOG_DFATAL COMPACT_GOOGLE_LOG_ERROR #define COMPACT_GOOGLE_LOG_DFATAL COMPACT_GOOGLE_LOG_ERROR
#elif GOOGLE_STRIP_LOG <= 3 #elif GOOGLE_STRIP_LOG <= 3
#define COMPACT_GOOGLE_LOG_DFATAL @ac_google_namespace@::LogMessage( \ #define COMPACT_GOOGLE_LOG_DFATAL @ac_google_namespace@::LogMessage( \
...@@ -572,7 +578,7 @@ class LogSink; // defined below ...@@ -572,7 +578,7 @@ class LogSink; // defined below
SYSLOG_IF(FATAL, !(condition)) << "Assert failed: " #condition SYSLOG_IF(FATAL, !(condition)) << "Assert failed: " #condition
// CHECK dies with a fatal error if condition is not true. It is *not* // CHECK dies with a fatal error if condition is not true. It is *not*
// controlled by NDEBUG, so the check will be executed regardless of // controlled by DCHECK_IS_ON(), so the check will be executed regardless of
// compilation mode. Therefore, it is safe to do things like: // compilation mode. Therefore, it is safe to do things like:
// CHECK(fp->Write(x) == 4) // CHECK(fp->Write(x) == 4)
#define CHECK(condition) \ #define CHECK(condition) \
...@@ -722,7 +728,7 @@ DEFINE_CHECK_OP_IMPL(Check_GT, > ) ...@@ -722,7 +728,7 @@ DEFINE_CHECK_OP_IMPL(Check_GT, > )
#if defined(STATIC_ANALYSIS) #if defined(STATIC_ANALYSIS)
// Only for static analysis tool to know that it is equivalent to assert // Only for static analysis tool to know that it is equivalent to assert
#define CHECK_OP_LOG(name, op, val1, val2, log) CHECK((val1) op (val2)) #define CHECK_OP_LOG(name, op, val1, val2, log) CHECK((val1) op (val2))
#elif !defined(NDEBUG) #elif DCHECK_IS_ON()
// In debug mode, avoid constructing CheckOpStrings if possible, // In debug mode, avoid constructing CheckOpStrings if possible,
// to reduce the overhead of CHECK statments by 2x. // to reduce the overhead of CHECK statments by 2x.
// Real DCHECK-heavy tests have seen 1.5x speedups. // Real DCHECK-heavy tests have seen 1.5x speedups.
...@@ -751,7 +757,7 @@ typedef std::string _Check_string; ...@@ -751,7 +757,7 @@ typedef std::string _Check_string;
@ac_google_namespace@::GetReferenceableValue(val2), \ @ac_google_namespace@::GetReferenceableValue(val2), \
#val1 " " #op " " #val2)) \ #val1 " " #op " " #val2)) \
log(__FILE__, __LINE__, _result).stream() log(__FILE__, __LINE__, _result).stream()
#endif // STATIC_ANALYSIS, !NDEBUG #endif // STATIC_ANALYSIS, DCHECK_IS_ON()
#if GOOGLE_STRIP_LOG <= 3 #if GOOGLE_STRIP_LOG <= 3
#define CHECK_OP(name, op, val1, val2) \ #define CHECK_OP(name, op, val1, val2) \
...@@ -976,7 +982,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -976,7 +982,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
// Plus some debug-logging macros that get compiled to nothing for production // Plus some debug-logging macros that get compiled to nothing for production
#ifndef NDEBUG #if DCHECK_IS_ON()
#define DLOG(severity) LOG(severity) #define DLOG(severity) LOG(severity)
#define DVLOG(verboselevel) VLOG(verboselevel) #define DVLOG(verboselevel) VLOG(verboselevel)
...@@ -986,7 +992,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -986,7 +992,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
LOG_IF_EVERY_N(severity, condition, n) LOG_IF_EVERY_N(severity, condition, n)
#define DLOG_ASSERT(condition) LOG_ASSERT(condition) #define DLOG_ASSERT(condition) LOG_ASSERT(condition)
// debug-only checking. not executed in NDEBUG mode. // debug-only checking. executed if DCHECK_IS_ON().
#define DCHECK(condition) CHECK(condition) #define DCHECK(condition) CHECK(condition)
#define DCHECK_EQ(val1, val2) CHECK_EQ(val1, val2) #define DCHECK_EQ(val1, val2) CHECK_EQ(val1, val2)
#define DCHECK_NE(val1, val2) CHECK_NE(val1, val2) #define DCHECK_NE(val1, val2) CHECK_NE(val1, val2)
...@@ -1000,7 +1006,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -1000,7 +1006,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
#define DCHECK_STRNE(str1, str2) CHECK_STRNE(str1, str2) #define DCHECK_STRNE(str1, str2) CHECK_STRNE(str1, str2)
#define DCHECK_STRCASENE(str1, str2) CHECK_STRCASENE(str1, str2) #define DCHECK_STRCASENE(str1, str2) CHECK_STRCASENE(str1, str2)
#else // NDEBUG #else // !DCHECK_IS_ON()
#define DLOG(severity) \ #define DLOG(severity) \
true ? (void) 0 : @ac_google_namespace@::LogMessageVoidify() & LOG(severity) true ? (void) 0 : @ac_google_namespace@::LogMessageVoidify() & LOG(severity)
...@@ -1081,7 +1087,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -1081,7 +1087,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
while (false) \ while (false) \
GLOG_MSVC_POP_WARNING() CHECK_STRCASENE(str1, str2) GLOG_MSVC_POP_WARNING() CHECK_STRCASENE(str1, str2)
#endif // NDEBUG #endif // DCHECK_IS_ON()
// Log only in verbose mode. // Log only in verbose mode.
......
...@@ -435,9 +435,15 @@ DECLARE_bool(stop_logging_if_full_disk); ...@@ -435,9 +435,15 @@ DECLARE_bool(stop_logging_if_full_disk);
#define LOG_TO_STRING_FATAL(message) google::NullStreamFatal() #define LOG_TO_STRING_FATAL(message) google::NullStreamFatal()
#endif #endif
#if defined(NDEBUG) && !defined(DCHECK_ALWAYS_ON)
#define DCHECK_IS_ON() 0
#else
#define DCHECK_IS_ON() 1
#endif
// For DFATAL, we want to use LogMessage (as opposed to // For DFATAL, we want to use LogMessage (as opposed to
// LogMessageFatal), to be consistent with the original behavior. // LogMessageFatal), to be consistent with the original behavior.
#ifdef NDEBUG #if !DCHECK_IS_ON()
#define COMPACT_GOOGLE_LOG_DFATAL COMPACT_GOOGLE_LOG_ERROR #define COMPACT_GOOGLE_LOG_DFATAL COMPACT_GOOGLE_LOG_ERROR
#elif GOOGLE_STRIP_LOG <= 3 #elif GOOGLE_STRIP_LOG <= 3
#define COMPACT_GOOGLE_LOG_DFATAL google::LogMessage( \ #define COMPACT_GOOGLE_LOG_DFATAL google::LogMessage( \
...@@ -576,7 +582,7 @@ class LogSink; // defined below ...@@ -576,7 +582,7 @@ class LogSink; // defined below
SYSLOG_IF(FATAL, !(condition)) << "Assert failed: " #condition SYSLOG_IF(FATAL, !(condition)) << "Assert failed: " #condition
// CHECK dies with a fatal error if condition is not true. It is *not* // CHECK dies with a fatal error if condition is not true. It is *not*
// controlled by NDEBUG, so the check will be executed regardless of // controlled by DCHECK_IS_ON(), so the check will be executed regardless of
// compilation mode. Therefore, it is safe to do things like: // compilation mode. Therefore, it is safe to do things like:
// CHECK(fp->Write(x) == 4) // CHECK(fp->Write(x) == 4)
#define CHECK(condition) \ #define CHECK(condition) \
...@@ -726,7 +732,7 @@ DEFINE_CHECK_OP_IMPL(Check_GT, > ) ...@@ -726,7 +732,7 @@ DEFINE_CHECK_OP_IMPL(Check_GT, > )
#if defined(STATIC_ANALYSIS) #if defined(STATIC_ANALYSIS)
// Only for static analysis tool to know that it is equivalent to assert // Only for static analysis tool to know that it is equivalent to assert
#define CHECK_OP_LOG(name, op, val1, val2, log) CHECK((val1) op (val2)) #define CHECK_OP_LOG(name, op, val1, val2, log) CHECK((val1) op (val2))
#elif !defined(NDEBUG) #elif DCHECK_IS_ON()
// In debug mode, avoid constructing CheckOpStrings if possible, // In debug mode, avoid constructing CheckOpStrings if possible,
// to reduce the overhead of CHECK statments by 2x. // to reduce the overhead of CHECK statments by 2x.
// Real DCHECK-heavy tests have seen 1.5x speedups. // Real DCHECK-heavy tests have seen 1.5x speedups.
...@@ -755,7 +761,7 @@ typedef std::string _Check_string; ...@@ -755,7 +761,7 @@ typedef std::string _Check_string;
google::GetReferenceableValue(val2), \ google::GetReferenceableValue(val2), \
#val1 " " #op " " #val2)) \ #val1 " " #op " " #val2)) \
log(__FILE__, __LINE__, _result).stream() log(__FILE__, __LINE__, _result).stream()
#endif // STATIC_ANALYSIS, !NDEBUG #endif // STATIC_ANALYSIS, DCHECK_IS_ON()
#if GOOGLE_STRIP_LOG <= 3 #if GOOGLE_STRIP_LOG <= 3
#define CHECK_OP(name, op, val1, val2) \ #define CHECK_OP(name, op, val1, val2) \
...@@ -980,7 +986,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -980,7 +986,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
// Plus some debug-logging macros that get compiled to nothing for production // Plus some debug-logging macros that get compiled to nothing for production
#ifndef NDEBUG #if DCHECK_IS_ON()
#define DLOG(severity) LOG(severity) #define DLOG(severity) LOG(severity)
#define DVLOG(verboselevel) VLOG(verboselevel) #define DVLOG(verboselevel) VLOG(verboselevel)
...@@ -990,7 +996,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -990,7 +996,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
LOG_IF_EVERY_N(severity, condition, n) LOG_IF_EVERY_N(severity, condition, n)
#define DLOG_ASSERT(condition) LOG_ASSERT(condition) #define DLOG_ASSERT(condition) LOG_ASSERT(condition)
// debug-only checking. not executed in NDEBUG mode. // debug-only checking. executed if DCHECK_IS_ON().
#define DCHECK(condition) CHECK(condition) #define DCHECK(condition) CHECK(condition)
#define DCHECK_EQ(val1, val2) CHECK_EQ(val1, val2) #define DCHECK_EQ(val1, val2) CHECK_EQ(val1, val2)
#define DCHECK_NE(val1, val2) CHECK_NE(val1, val2) #define DCHECK_NE(val1, val2) CHECK_NE(val1, val2)
...@@ -1004,7 +1010,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -1004,7 +1010,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
#define DCHECK_STRNE(str1, str2) CHECK_STRNE(str1, str2) #define DCHECK_STRNE(str1, str2) CHECK_STRNE(str1, str2)
#define DCHECK_STRCASENE(str1, str2) CHECK_STRCASENE(str1, str2) #define DCHECK_STRCASENE(str1, str2) CHECK_STRCASENE(str1, str2)
#else // NDEBUG #else // !DCHECK_IS_ON()
#define DLOG(severity) \ #define DLOG(severity) \
true ? (void) 0 : google::LogMessageVoidify() & LOG(severity) true ? (void) 0 : google::LogMessageVoidify() & LOG(severity)
...@@ -1085,7 +1091,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR; ...@@ -1085,7 +1091,7 @@ const LogSeverity GLOG_0 = GLOG_ERROR;
while (false) \ while (false) \
GLOG_MSVC_POP_WARNING() CHECK_STRCASENE(str1, str2) GLOG_MSVC_POP_WARNING() CHECK_STRCASENE(str1, str2)
#endif // NDEBUG #endif // DCHECK_IS_ON()
// Log only in verbose mode. // Log only in verbose mode.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment