blob: a6b2dbdef6abd6bbf36b1c89f02aa4b7d6bb80f4 [file] [log] [blame]
Chris Lattnerf3f4fd52002-05-10 15:36:46 +00001//===-- StatisticReporter.cpp - Easy way to expose stats information -------==//
2//
3// This file implements the 'Statistic' class, which is designed to be an easy
4// way to expose various success metrics from passes. These statistics are
5// printed at the end of a run, when the -stats command line option is enabled
6// on the command line.
7//
8// This is useful for reporting information like the number of instructions
9// simplified, optimized or removed by various transformations, like this:
10//
11// static Statistic<> NumInstEliminated("GCSE - Number of instructions killed");
12//
13// Later, in the code: ++NumInstEliminated;
14//
15//===----------------------------------------------------------------------===//
16
17#include "Support/StatisticReporter.h"
18#include "Support/CommandLine.h"
19#include <iostream>
20
Chris Lattner4435ac02002-05-22 17:06:20 +000021bool DebugFlag; // DebugFlag - Exported boolean set by the -debug option
22
Chris Lattner5ff62e92002-07-22 02:10:13 +000023// -stats - Command line option to cause transformations to emit stats about
24// what they did.
25//
26static cl::opt<bool>
27Enabled("stats", cl::desc("Enable statistics output from program"));
28
29// -debug - Command line option to enable the DEBUG statements in the passes.
30static cl::opt<bool, true>
31Debug("debug", cl::desc("Enable debug output"), cl::Hidden,
32 cl::location(DebugFlag));
Chris Lattnerf3f4fd52002-05-10 15:36:46 +000033
34// Print information when destroyed, iff command line option is specified
35void StatisticBase::destroy() const {
36 if (Enabled && hasSomeData()) {
37 std::cerr.width(7);
38 printValue(std::cerr);
39 std::cerr.width(0);
40 std::cerr << "\t" << Name << "\n";
41 }
42}