1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-12-22 22:13:35 +02:00

timeHandler: FreeBSD fixes, based on plush's patch ( #719 ).

Aesthetic „fixes”.
This commit is contained in:
Michał W. Urbańczyk 2011-04-02 23:45:47 +00:00
parent 21eaec883c
commit 6d52bb5842

View File

@ -1,7 +1,15 @@
#ifndef __TIMEHANDLER_H__ #ifndef __TIMEHANDLER_H__
#define __TIMEHANDLER_H__ #define __TIMEHANDLER_H__
#include <ctime> #ifdef __FreeBSD__
#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
/* /*
* timeHandler.h, part of VCMI engine * timeHandler.h, part of VCMI engine
@ -15,13 +23,43 @@
class timeHandler class timeHandler
{ {
public:
clock_t start, last, mem; clock_t start, last, mem;
timeHandler():start(clock()){last=clock();mem=0;}; public:
long getDif(){long ret=clock()-last;last=clock();return ret/(CLOCKS_PER_SEC/1000);};//get diff in milliseconds timeHandler()
void update(){last=clock();}; : start(clock())
void remember(){mem=clock();}; {
long memDif(){return clock()-mem;}; last=clock();
mem=0;
}
long getDif() //get diff in milliseconds
{
long ret=clock()-last;
last=clock();
return ret/TO_MS_DIVISOR;
}
void update()
{
last=clock();
}
void remember()
{
mem=clock();
}
long memDif()
{
return clock()-mem;
}
long clock()
{
#ifdef __FreeBSD__
struct rusage usage;
getrusage(RUSAGE_SELF, &usage);
return static_cast<long>(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
}
}; };