mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-01 00:11:00 +00:00
4435ac0097
the random debugging macros scattered throughout llvm. The new DEBUG(x) macro should be used instead of special purpose debug macros. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2709 91177308-0d34-0410-b5e6-96231b3b80d8
35 lines
1.3 KiB
C++
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";
|
|
}
|
|
}
|