diff options
author | Daniel Wilhelm <daniel@wili.li> | 2014-04-18 17:08:06 +0200 |
---|---|---|
committer | Daniel Wilhelm <daniel@wili.li> | 2014-04-18 17:08:06 +0200 |
commit | fbe76102e941b9f1edaf236788e42678f05fdf9a (patch) | |
tree | f5f538316019fa89be8dc478103490c3a826f3ac /shared/perf.h | |
parent | 3.8 (diff) | |
download | FreeFileSync-fbe76102e941b9f1edaf236788e42678f05fdf9a.tar.gz FreeFileSync-fbe76102e941b9f1edaf236788e42678f05fdf9a.tar.bz2 FreeFileSync-fbe76102e941b9f1edaf236788e42678f05fdf9a.zip |
3.9
Diffstat (limited to 'shared/perf.h')
-rw-r--r-- | shared/perf.h | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/shared/perf.h b/shared/perf.h new file mode 100644 index 00000000..62473259 --- /dev/null +++ b/shared/perf.h @@ -0,0 +1,42 @@ +// ************************************************************************** +// * This file is part of the FreeFileSync project. It is distributed under * +// * GNU General Public License: http://www.gnu.org/licenses/gpl.html * +// * Copyright (C) 2008-2010 ZenJu (zhnmju123 AT gmx.de) * +// ************************************************************************** +// +#include <windows.h> +#include <sstream> + +class Performance +{ +public: + Performance() : resultWasShown(false), startTime(::GetTickCount()) {} + + ~Performance() + { + if (!resultWasShown) + showResult(); + } + + void showResult() + { + resultWasShown = true; + + const DWORD currentTime = ::GetTickCount(); + const DWORD delta = currentTime - startTime; + startTime = currentTime; + + std::ostringstream ss; + ss << delta << " ms"; + + ::MessageBoxA(NULL, ss.str().c_str(), "Timer", 0); + } + +private: + bool resultWasShown; + DWORD startTime; +}; + +//two macros for quick performance measurements +#define PERF_START Performance a; +#define PERF_STOP a.showResult(); |