From 0796f771c37ec5287c791038051420c5e014f6f2 Mon Sep 17 00:00:00 2001 From: Evan Martin Date: Sun, 1 May 2011 20:01:46 -0700 Subject: windows: use millis abstraction instead of non-portable gettimeofday --- src/build.cc | 42 ++++++++++++++++++++++++++++-------------- 1 file changed, 28 insertions(+), 14 deletions(-) diff --git a/src/build.cc b/src/build.cc index 2549553..f6b9b64 100644 --- a/src/build.cc +++ b/src/build.cc @@ -15,7 +15,10 @@ #include "build.h" #include -#ifndef WIN32 + +#ifdef _WIN32 +#include +#else #include #include #include @@ -26,6 +29,21 @@ #include "ninja.h" #include "subprocess.h" +namespace { + +int64_t GetTimeMillis() { +#ifdef _WIN32 + // GetTickCount64 is only available on Vista or later. + return GetTickCount(); +#else + timeval now; + gettimeofday(&now, NULL); + return ((int64_t)now.tv_sec * 1000) + (now.tv_usec / 1000); +#endif +} + +} + /// Tracks the status of a build: completion fraction, printing updates. struct BuildStatus { BuildStatus(); @@ -36,10 +54,10 @@ struct BuildStatus { void PrintStatus(Edge* edge); - time_t last_update_; + int64_t last_update_millis_; int finished_edges_, total_edges_; - typedef map RunningEdgeMap; + typedef map RunningEdgeMap; RunningEdgeMap running_edges_; BuildConfig::Verbosity verbosity_; @@ -48,7 +66,8 @@ struct BuildStatus { }; BuildStatus::BuildStatus() - : last_update_(time(NULL)), finished_edges_(0), total_edges_(0), + : last_update_millis_(GetTimeMillis()), + finished_edges_(0), total_edges_(0), verbosity_(BuildConfig::NORMAL) { #ifndef WIN32 const char* term = getenv("TERM"); @@ -63,16 +82,13 @@ void BuildStatus::PlanHasTotalEdges(int total) { } void BuildStatus::BuildEdgeStarted(Edge* edge) { - timeval now; - gettimeofday(&now, NULL); - running_edges_.insert(make_pair(edge, now)); + running_edges_.insert(make_pair(edge, GetTimeMillis())); PrintStatus(edge); } int BuildStatus::BuildEdgeFinished(Edge* edge) { - timeval now; - gettimeofday(&now, NULL); + int64_t now = GetTimeMillis(); ++finished_edges_; if (verbosity_ != BuildConfig::QUIET) { @@ -81,18 +97,16 @@ int BuildStatus::BuildEdgeFinished(Edge* edge) { if (finished_edges_ == total_edges_) printf("\n"); } else { - if (now.tv_sec - last_update_ > 5) { + if (now - last_update_millis_ > 5*1000) { printf("%.1f%% %d/%d\n", finished_edges_ * 100 / (float)total_edges_, finished_edges_, total_edges_); - last_update_ = now.tv_sec; + last_update_millis_ = now; } } } RunningEdgeMap::iterator i = running_edges_.find(edge); - timeval delta; - timersub(&now, &i->second, &delta); - int ms = (delta.tv_sec * 1000) + (delta.tv_usec / 1000); + int ms = (int)(now - i->second); running_edges_.erase(i); return ms; -- cgit v0.12