1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-18 03:21:27 +02:00
vcmi/lib/CStopWatch.h

69 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
*
*/
2011-12-14 00:35:28 +03:00
#pragma once
#ifdef __FreeBSD__
#include <sys/types.h>
#include <sys/time.h>
#include <sys/resource.h>
#define TO_MS_DIVISOR (1000)
#else
#include <ctime>
2011-12-14 00:35:28 +03:00
#define TO_MS_DIVISOR (CLOCKS_PER_SEC / 1000)
#endif
VCMI_LIB_NAMESPACE_BEGIN
class CStopWatch
{
2011-12-14 00:35:28 +03:00
si64 start, last, mem;
public:
CStopWatch()
: start(clock())
{
last=clock();
mem=0;
}
2011-12-14 00:35:28 +03:00
si64 getDiff() //get diff in milliseconds
{
2011-12-14 00:35:28 +03:00
si64 ret = clock() - last;
last = clock();
return ret / TO_MS_DIVISOR;
}
void update()
{
last=clock();
}
void remember()
{
mem=clock();
}
2011-12-14 00:35:28 +03:00
si64 memDif()
{
return (clock()-mem) / TO_MS_DIVISOR;
}
2011-12-14 00:35:28 +03:00
private:
si64 clock()
{
2021-03-07 18:18:26 +02:00
#ifdef __FreeBSD__ // TODO: enable also for Apple?
struct rusage usage;
getrusage(RUSAGE_SELF, &usage);
2011-12-14 00:35:28 +03:00
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