diff options
author | Chris Lattner <sabre@nondot.org> | 2003-08-01 22:15:41 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-08-01 22:15:41 +0000 |
commit | 8fb754a5b92f5d93795bcd900d3e760f117fe238 (patch) | |
tree | 07e9b6bdb4f7b1079e2f3881572d3a80b9ea712c /llvm/lib/Support/Debug.cpp | |
parent | f1afe323537daa7d23f6f8ec5941c4f3de4cc658 (diff) | |
download | bcm5719-llvm-8fb754a5b92f5d93795bcd900d3e760f117fe238.tar.gz bcm5719-llvm-8fb754a5b92f5d93795bcd900d3e760f117fe238.zip |
Move debug functionality to Debug.cpp/Debug.h
llvm-svn: 7494
Diffstat (limited to 'llvm/lib/Support/Debug.cpp')
-rw-r--r-- | llvm/lib/Support/Debug.cpp | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/llvm/lib/Support/Debug.cpp b/llvm/lib/Support/Debug.cpp new file mode 100644 index 00000000000..57ed27a5b95 --- /dev/null +++ b/llvm/lib/Support/Debug.cpp @@ -0,0 +1,53 @@ +//===-- Debug.cpp - An easy way to add debug output to your code ----------===// +// +// This file implements a handle way of adding debugging information to your +// code, without it being enabled all of the time, and without having to add +// command line options to enable it. +// +// In particular, just wrap your code with the DEBUG() macro, and it will be +// enabled automatically if you specify '-debug' on the command-line. +// Alternatively, you can also use the SET_DEBUG_TYPE("foo") macro to specify +// that your debug code belongs to class "foo". Then, on the command line, you +// can specify '-debug-only=foo' to enable JUST the debug information for the +// foo class. +// +// When compiling in release mode, the -debug-* options and all code in DEBUG() +// statements disappears, so it does not effect the runtime of the code. +// +//===----------------------------------------------------------------------===// + +#include "Support/Statistic.h" +#include "Support/CommandLine.h" + +bool DebugFlag; // DebugFlag - Exported boolean set by the -debug option + +namespace { +#ifndef NDEBUG + // -debug - Command line option to enable the DEBUG statements in the passes. + // This flag may only be enabled in debug builds. + cl::opt<bool, true> + Debug("debug", cl::desc("Enable debug output"), cl::Hidden, + cl::location(DebugFlag)); + + std::string CurrentDebugType; + struct DebugOnlyOpt { + void operator=(const std::string &Val) const { + DebugFlag |= !Val.empty(); + CurrentDebugType = Val; + } + } DebugOnlyOptLoc; + + cl::opt<DebugOnlyOpt, true, cl::parser<std::string> > + DebugOnly("debug-only", cl::desc("Enable a specific type of debug output"), + cl::Hidden, cl::value_desc("debug string"), + cl::location(DebugOnlyOptLoc), cl::ValueRequired); +#endif +} + +// isCurrentDebugType - Return true if the specified string is the debug type +// specified on the command line, or if none was specified on the command line +// with the -debug-only=X option. +// +bool isCurrentDebugType(const char *DebugType) { + return CurrentDebugType.empty() || DebugType == CurrentDebugType; +} |