forked from OSchip/llvm-project
Refactor statistic a big and introduce a horrible-but-necessary macro
(STATISTIC), which allows us to define statistics that don't introduce static ctors into the .o files. I'm migrating code over to use this incrementally. llvm-svn: 32687
This commit is contained in:
parent
2acb8e1a43
commit
13bfd32f5d
|
@ -28,16 +28,12 @@
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
class Statistic {
|
class StatisticBase {
|
||||||
|
public:
|
||||||
const char *Name;
|
const char *Name;
|
||||||
const char *Desc;
|
const char *Desc;
|
||||||
unsigned Value : 31;
|
unsigned Value : 31;
|
||||||
bool Initialized : 1;
|
bool Initialized : 1;
|
||||||
public:
|
|
||||||
// Normal constructor, default initialize data item...
|
|
||||||
Statistic(const char *name, const char *desc)
|
|
||||||
: Name(name), Desc(desc), Value(0), Initialized(0) {
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned getValue() const { return Value; }
|
unsigned getValue() const { return Value; }
|
||||||
const char *getName() const { return Name; }
|
const char *getName() const { return Name; }
|
||||||
|
@ -45,24 +41,36 @@ public:
|
||||||
|
|
||||||
// Allow use of this class as the value itself.
|
// Allow use of this class as the value itself.
|
||||||
operator unsigned() const { return Value; }
|
operator unsigned() const { return Value; }
|
||||||
const Statistic &operator=(unsigned Val) { Value = Val; return init(); }
|
const StatisticBase &operator=(unsigned Val) { Value = Val; return init(); }
|
||||||
const Statistic &operator++() { ++Value; return init(); }
|
const StatisticBase &operator++() { ++Value; return init(); }
|
||||||
unsigned operator++(int) { init(); return Value++; }
|
unsigned operator++(int) { init(); return Value++; }
|
||||||
const Statistic &operator--() { --Value; return init(); }
|
const StatisticBase &operator--() { --Value; return init(); }
|
||||||
unsigned operator--(int) { init(); return Value--; }
|
unsigned operator--(int) { init(); return Value--; }
|
||||||
const Statistic &operator+=(const unsigned &V) { Value += V; return init(); }
|
const StatisticBase &operator+=(const unsigned &V) {Value += V;return init();}
|
||||||
const Statistic &operator-=(const unsigned &V) { Value -= V; return init(); }
|
const StatisticBase &operator-=(const unsigned &V) {Value -= V;return init();}
|
||||||
const Statistic &operator*=(const unsigned &V) { Value *= V; return init(); }
|
const StatisticBase &operator*=(const unsigned &V) {Value *= V;return init();}
|
||||||
const Statistic &operator/=(const unsigned &V) { Value /= V; return init(); }
|
const StatisticBase &operator/=(const unsigned &V) {Value /= V;return init();}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Statistic &init() {
|
StatisticBase &init() {
|
||||||
if (!Initialized) RegisterStatistic();
|
if (!Initialized) RegisterStatistic();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
void RegisterStatistic();
|
void RegisterStatistic();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct Statistic : public StatisticBase {
|
||||||
|
Statistic(const char *name, const char *desc) {
|
||||||
|
Name = name; Desc = desc; Value = 0; Initialized = 0;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// STATISTIC - A macro to make definition of statistics really simple. This
|
||||||
|
// automatically passes the DEBUG_TYPE of the file into the statistic.
|
||||||
|
#define STATISTIC(VARNAME, DESC) \
|
||||||
|
static StatisticBase VARNAME = { DEBUG_TYPE, DESC, 0, 0 }
|
||||||
|
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -45,11 +45,11 @@ namespace {
|
||||||
/// on demand (when the first statistic is bumped) and destroyed only when
|
/// on demand (when the first statistic is bumped) and destroyed only when
|
||||||
/// llvm_shutdown is called. We print statistics from the destructor.
|
/// llvm_shutdown is called. We print statistics from the destructor.
|
||||||
class StatisticInfo {
|
class StatisticInfo {
|
||||||
std::vector<const Statistic*> Stats;
|
std::vector<const StatisticBase*> Stats;
|
||||||
public:
|
public:
|
||||||
~StatisticInfo();
|
~StatisticInfo();
|
||||||
|
|
||||||
void addStatistic(const Statistic *S) {
|
void addStatistic(const StatisticBase *S) {
|
||||||
Stats.push_back(S);
|
Stats.push_back(S);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -60,7 +60,7 @@ static ManagedStatic<StatisticInfo> StatInfo;
|
||||||
|
|
||||||
/// RegisterStatistic - The first time a statistic is bumped, this method is
|
/// RegisterStatistic - The first time a statistic is bumped, this method is
|
||||||
/// called.
|
/// called.
|
||||||
void Statistic::RegisterStatistic() {
|
void StatisticBase::RegisterStatistic() {
|
||||||
// If stats are enabled, inform StatInfo that this statistic should be
|
// If stats are enabled, inform StatInfo that this statistic should be
|
||||||
// printed.
|
// printed.
|
||||||
if (Enabled)
|
if (Enabled)
|
||||||
|
@ -70,7 +70,7 @@ void Statistic::RegisterStatistic() {
|
||||||
}
|
}
|
||||||
|
|
||||||
struct NameCompare {
|
struct NameCompare {
|
||||||
bool operator()(const Statistic *LHS, const Statistic *RHS) const {
|
bool operator()(const StatisticBase *LHS, const StatisticBase *RHS) const {
|
||||||
int Cmp = std::strcmp(LHS->getName(), RHS->getName());
|
int Cmp = std::strcmp(LHS->getName(), RHS->getName());
|
||||||
if (Cmp != 0) return Cmp < 0;
|
if (Cmp != 0) return Cmp < 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue