1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-12-12 10:03:53 +02:00
vcmi/lib/CStopWatch.h

71 lines
1.2 KiB
C++
Raw Normal View History

/*
* CStopWatch.h, part of VCMI engine
*
* Authors: listed in file AUTHORS in main folder
*
* License: GNU General Public License v2.0 or later
* Full text of license available in license.txt file, in main folder
*
*/
#pragma once
2023-12-14 09:29:42 +02:00
#if defined(__FreeBSD__) || defined(__OpenBSD__)
#include <sys/types.h>
#include <sys/time.h>
#include <sys/resource.h>
#define TO_MS_DIVISOR (1000)
#else
#include <ctime>
#define TO_MS_DIVISOR (CLOCKS_PER_SEC / 1000)
#endif
VCMI_LIB_NAMESPACE_BEGIN
class CStopWatch
{
si64 start;
si64 last;
si64 mem;
public:
CStopWatch()
: start(clock())
{
last=clock();
mem=0;
}
si64 getDiff() //get diff in milliseconds
{
si64 ret = clock() - last;
last = clock();
return ret / TO_MS_DIVISOR;
}
void update()
{
last=clock();
}
void remember()
{
mem=clock();
}
si64 memDif()
{
return (clock()-mem) / TO_MS_DIVISOR;
}
private:
si64 clock()
{
2023-12-14 09:29:42 +02:00
#if defined(__FreeBSD__) || defined(__OpenBSD__) // TODO: enable also for Apple?
struct rusage usage;
getrusage(RUSAGE_SELF, &usage);
return static_cast<si64>(usage.ru_utime.tv_sec + usage.ru_stime.tv_sec) * 1000000 + usage.ru_utime.tv_usec + usage.ru_stime.tv_usec;
#else
return std::clock();
#endif
}
};
VCMI_LIB_NAMESPACE_END