#include "timing_stats.h"

#include <iostream>
#include "time.h" //cygwin needs

#include "verbose.h"

using namespace std;

map<string, TimerInfo> Timer::stats;

Timer::Timer(const string& timername) : start_t(clock()), cur(stats[timername]) {}

Timer::~Timer() {
  ++cur.calls;
  const clock_t end_t = clock();
  const double elapsed = (end_t - start_t) / 1000000.0;
  cur.total_time += elapsed;
}

void Timer::Summarize() {
  if (!SILENT) {
    for (map<string, TimerInfo>::iterator it = stats.begin(); it != stats.end(); ++it) {
      cerr << it->first << ": " << it->second.total_time << " secs (" << it->second.calls << " calls)\n";
    }
  }
  stats.clear();
}