blob: 7c3dae8cd750234aadd1558396c0a1dfcf5a487c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
#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);
}
}
|