ソースを参照

CLoggerBase: Use IvanSavenko's single-statement macro so that ct100 is not immediately destroyed

Alexander Wilms 1 年間 前
コミット
d2b105f216
1 ファイル変更4 行追加3 行削除
  1. 4 3
      include/vstd/CLoggerBase.h

+ 4 - 3
include/vstd/CLoggerBase.h

@@ -172,9 +172,10 @@ private:
 /// Macros for tracing the control flow of the application conveniently. If the LOG_TRACE macro is used it should be
 /// the first statement in the function. Logging traces via this macro have almost no impact when the trace is disabled.
 ///
-#define RAII_TRACE(logger, onEntry, onLeave)			\
-	if(logger->isTraceEnabled())						\
-		std::unique_ptr<vstd::CTraceLogger> ctl00 = std::make_unique<vstd::CTraceLogger>(logger, onEntry, onLeave)
+#define RAII_TRACE(logger, onEntry, onLeave)								\
+	std::unique_ptr<vstd::CTraceLogger> ctl00 = logger->isTraceEnabled() ?	\
+	std::make_unique<vstd::CTraceLogger>(logger, onEntry, onLeave) :		\
+    std::unique_ptr<vstd::CTraceLogger>()
 
 #define LOG_TRACE(logger) RAII_TRACE(logger,								\
 		boost::str(boost::format("Entering %s.") % BOOST_CURRENT_FUNCTION),	\