openspades/Sources/Core/Stopwatch.cpp

42 lines
768 B
C++
Raw Normal View History

2013-08-18 16:18:06 +09:00
//
// Stopwatch.cpp
// OpenSpades
//
// Created by yvt on 7/14/13.
// Copyright (c) 2013 yvt.jp. All rights reserved.
//
#include "Stopwatch.h"
#include "../Imports/SDL.h"
#include "Debug.h"
2013-08-25 08:18:00 +09:00
#ifdef WIN32
#include <windows.h>
static uint64_t GetSWTicks() {
LARGE_INTEGER val, freq;
QueryPerformanceCounter(&val);
QueryPerformanceFrequency(&freq);
return (double)val.QuadPart / (double)freq.QuadPart;
}
#else
#include <sys/time.h>
static double GetSWTicks() {
struct timeval val;
gettimeofday(&val, NULL);
return (double)val.tv_usec / 1000000. +
(double)val.tv_sec;
}
#endif
2013-08-18 16:18:06 +09:00
namespace spades {
Stopwatch::Stopwatch(){
Reset();
}
void Stopwatch::Reset() {
2013-08-25 08:18:00 +09:00
start = GetSWTicks();
2013-08-18 16:18:06 +09:00
}
2013-08-25 08:18:00 +09:00
double Stopwatch::GetTime() {
return GetSWTicks() - start;
2013-08-18 16:18:06 +09:00
}
}