summaryrefslogtreecommitdiff
path: root/include/llvm/Support/Debug.h
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-08-07 23:48:59 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-08-07 23:48:59 +0000
commitc3c9239d76e2acb01dac8c72323a0b28fadebe4b (patch)
tree9aa7c034cf40476365e7a8028beff6c7bd7c2317 /include/llvm/Support/Debug.h
parente9ce5d5ef94c04a6316a5368a4927f9a34ae2a2f (diff)
downloadllvm-c3c9239d76e2acb01dac8c72323a0b28fadebe4b.tar.gz
llvm-c3c9239d76e2acb01dac8c72323a0b28fadebe4b.tar.bz2
llvm-c3c9239d76e2acb01dac8c72323a0b28fadebe4b.tar.xz
Add DEBUG_WITH_TYPE as a clean alternative to tweaking DEBUG_TYPE.
This: -- #undef DEBUG_TYPE #define DEBUG_TYPE "foo" DEBUG(...) #undef DEBUG_TYPE #define DEBUG_TYPE "" -- becomes this: -- DEBUG_WITH_TYPE("foo", ...) -- git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78435 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Support/Debug.h')
-rw-r--r--include/llvm/Support/Debug.h26
1 files changed, 19 insertions, 7 deletions
diff --git a/include/llvm/Support/Debug.h b/include/llvm/Support/Debug.h
index 69544de911..17dca21609 100644
--- a/include/llvm/Support/Debug.h
+++ b/include/llvm/Support/Debug.h
@@ -42,24 +42,36 @@ extern bool DebugFlag;
//
bool isCurrentDebugType(const char *Type);
+// DEBUG_WITH_TYPE macro - This macro should be used by passes to emit debug
+// information. In the '-debug' option is specified on the commandline, and if
+// this is a debug build, then the code specified as the option to the macro
+// will be executed. Otherwise it will not be. Example:
+//
+// DEBUG_WITH_TYPE("bitset", errs() << "Bitset contains: " << Bitset << "\n");
+//
+// This will emit the debug information if -debug is present, and -debug-only is
+// not specified, or is specified as "bitset".
+
+#ifdef NDEBUG
+#define DEBUG_WITH_TYPE(TYPE, X) do { } while (0)
+#else
+#define DEBUG_WITH_TYPE(TYPE, X) \
+ do { if (DebugFlag && isCurrentDebugType(TYPE)) { X; } } while (0)
+#endif
+
// DEBUG macro - This macro should be used by passes to emit debug information.
// In the '-debug' option is specified on the commandline, and if this is a
// debug build, then the code specified as the option to the macro will be
// executed. Otherwise it will not be. Example:
//
-// DEBUG(cerr << "Bitset contains: " << Bitset << "\n");
+// DEBUG(errs() << "Bitset contains: " << Bitset << "\n");
//
#ifndef DEBUG_TYPE
#define DEBUG_TYPE ""
#endif
-#ifdef NDEBUG
-#define DEBUG(X)
-#else
-#define DEBUG(X) \
- do { if (DebugFlag && isCurrentDebugType(DEBUG_TYPE)) { X; } } while (0)
-#endif
+#define DEBUG(X) DEBUG_WITH_TYPE(DEBUG_TYPE, X)
/// getNullOutputStream - Return a null string that does not output
/// anything. This hides the static variable from other modules.