[llvm-commits] CVS: llvm/lib/Support/Debug.cpp Statistic.cpp
Chris Lattner
lattner at cs.uiuc.edu
Fri Aug 1 17:16:08 PDT 2003
Changes in directory llvm/lib/Support:
Debug.cpp added (r1.1)
Statistic.cpp updated: 1.8 -> 1.9
---
Log message:
Move debug functionality to Debug.cpp/Debug.h
---
Diffs of the changes:
Index: llvm/lib/Support/Debug.cpp
diff -c /dev/null llvm/lib/Support/Debug.cpp:1.1
*** /dev/null Fri Aug 1 17:15:51 2003
--- llvm/lib/Support/Debug.cpp Fri Aug 1 17:15:41 2003
***************
*** 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;
+ }
Index: llvm/lib/Support/Statistic.cpp
diff -u llvm/lib/Support/Statistic.cpp:1.8 llvm/lib/Support/Statistic.cpp:1.9
--- llvm/lib/Support/Statistic.cpp:1.8 Fri May 9 15:05:44 2003
+++ llvm/lib/Support/Statistic.cpp Fri Aug 1 17:15:41 2003
@@ -16,15 +16,12 @@
#include "Support/Statistic.h"
#include "Support/CommandLine.h"
-#include <iostream>
#include <sstream>
-#include <algorithm>
+#include <iostream>
// GetLibSupportInfoOutputFile - Return a file stream to print our output on...
std::ostream *GetLibSupportInfoOutputFile();
-bool DebugFlag; // DebugFlag - Exported boolean set by the -debug option
-
unsigned StatisticBase::NumStats = 0;
// -stats - Command line option to cause transformations to emit stats about
@@ -32,14 +29,6 @@
//
static cl::opt<bool>
Enabled("stats", cl::desc("Enable statistics output from program"));
-
-#ifndef NDEBUG
-// -debug - Command line option to enable the DEBUG statements in the passes.
-// This flag may only be enabled in debug builds.
-static cl::opt<bool, true>
-Debug("debug", cl::desc("Enable debug output"), cl::Hidden,
- cl::location(DebugFlag));
-#endif
struct StatRecord {
std::string Value;
More information about the llvm-commits
mailing list