1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-19 11:02:59 +02:00
llvm-mirror/support/lib/Support/StatisticReporter.cpp
Chris Lattner 7f8f0b5863 Implement a new command line option, -debug, which is meant to unify all of
the random debugging macros scattered throughout llvm.

The new DEBUG(x) macro should be used instead of special purpose debug macros.

llvm-svn: 2709
2002-05-22 17:06:20 +00:00

35 lines
1.3 KiB
C++

//===-- StatisticReporter.cpp - Easy way to expose stats information -------==//
//
// This file implements the 'Statistic' class, which is designed to be an easy
// way to expose various success metrics from passes. These statistics are
// printed at the end of a run, when the -stats command line option is enabled
// on the command line.
//
// This is useful for reporting information like the number of instructions
// simplified, optimized or removed by various transformations, like this:
//
// static Statistic<> NumInstEliminated("GCSE - Number of instructions killed");
//
// Later, in the code: ++NumInstEliminated;
//
//===----------------------------------------------------------------------===//
#include "Support/StatisticReporter.h"
#include "Support/CommandLine.h"
#include <iostream>
bool DebugFlag; // DebugFlag - Exported boolean set by the -debug option
static cl::Flag Enabled("stats", "Enable statistics output from program");
static cl::Flag Debug(DebugFlag, "debug", "Enable debug output", cl::Hidden);
// Print information when destroyed, iff command line option is specified
void StatisticBase::destroy() const {
if (Enabled && hasSomeData()) {
std::cerr.width(7);
printValue(std::cerr);
std::cerr.width(0);
std::cerr << "\t" << Name << "\n";
}
}