Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
G
glog
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
glog
Commits
ab654547
Commit
ab654547
authored
Feb 09, 2017
by
Fumitoshi Ukai
Committed by
GitHub
Feb 09, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #164 from yoshisatoyanagisawa/dcheck_always_on
DCHECK_ALWAYS_ON to make D* enabled under NDEBUG
parents
b6a5e052
027332ff
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
28 additions
and
16 deletions
+28
-16
logging.h.in
src/glog/logging.h.in
+14
-8
logging.h
src/windows/glog/logging.h
+14
-8
No files found.
src/glog/logging.h.in
View file @
ab654547
...
@@ -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.
#if
def 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
#if
ndef 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.
...
...
src/windows/glog/logging.h
View file @
ab654547
...
@@ -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.
#if
def 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
#if
ndef 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.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment