Mercurial > fife-parpg
view ext/UnitTest++/src/Win32/TimeHelpers.cpp @ 197:80b3c41c3427
* Updated win32 build scripts to work with the new compile SDK
* Download the SDK here: http://downloads.sourceforge.net/fife/FIFE_2009.0_win32_SDK.7z
* List of changes and further details can be found here: http://fifengine.de/2009/03/11/new-win32-compile-sdk-released-20090/
* The 2008.0-r4 SDK won't work anymore since this commit.
author | mvbarracuda@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Wed, 11 Mar 2009 21:09:39 +0000 |
parents | 0d325e9d5953 |
children |
line wrap: on
line source
#include "TimeHelpers.h" #include <windows.h> namespace UnitTest { Timer::Timer() : m_startTime(0) { m_threadId = ::GetCurrentThread(); DWORD_PTR systemMask; ::GetProcessAffinityMask(GetCurrentProcess(), &m_processAffinityMask, &systemMask); ::SetThreadAffinityMask(m_threadId, 1); ::QueryPerformanceFrequency(reinterpret_cast< LARGE_INTEGER* >(&m_frequency)); ::SetThreadAffinityMask(m_threadId, m_processAffinityMask); } void Timer::Start() { m_startTime = GetTime(); } int Timer::GetTimeInMs() const { __int64 const elapsedTime = GetTime() - m_startTime; double const seconds = double(elapsedTime) / double(m_frequency); return int(seconds * 1000.0f); } __int64 Timer::GetTime() const { LARGE_INTEGER curTime; ::SetThreadAffinityMask(m_threadId, 1); ::QueryPerformanceCounter(&curTime); ::SetThreadAffinityMask(m_threadId, m_processAffinityMask); return curTime.QuadPart; } void TimeHelpers::SleepMs(int const ms) { ::Sleep(ms); } }