Fixed issue #1789: Tooltips not properly displayed in Log List if that commit has...
[TortoiseGit.git] / src / Utils / HighResClock.h
blobab712352b12312d2191f5e8a6273027123f34cda
1 // TortoiseGit - a Windows shell extension for easy version control
3 // Copyright (C) 2007-2007 - TortoiseSVN
5 // This program is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU General Public License
7 // as published by the Free Software Foundation; either version 2
8 // of the License, or (at your option) any later version.
10 // This program is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // GNU General Public License for more details.
15 // You should have received a copy of the GNU General Public License
16 // along with this program; if not, write to the Free Software Foundation,
17 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
19 #pragma once
21 ///////////////////////////////////////////////////////////////
23 // CHighResClock
25 // high resolution clock for performance measurement.
26 // Depending on the hardware it will provide µsec
27 // resolution and accuracy.
29 // May not be available on all machines.
31 ///////////////////////////////////////////////////////////////
33 class CHighResClock
35 private:
37 LARGE_INTEGER start;
38 LARGE_INTEGER taken;
40 public:
42 // construction (starts measurement) / destruction
44 CHighResClock()
46 taken.QuadPart = 0;
47 Start();
50 ~CHighResClock()
54 // (re-start)
56 void Start()
58 QueryPerformanceCounter(&start);
61 // set "taken" to time since last Start()
63 void Stop()
65 QueryPerformanceCounter(&taken);
66 taken.QuadPart -= start.QuadPart;
69 // time in microseconds between last Start() and last Stop()
71 DWORD GetMusecsTaken() const
73 LARGE_INTEGER frequency;
74 QueryPerformanceFrequency(&frequency);
75 return (DWORD)((taken.QuadPart * 1000000) / frequency.QuadPart);