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
|
|
|
}
|
|
|
|
}
|