diff options
| author | n0n4m3 <none@none> | 2009-12-24 10:20:15 +0100 |
|---|---|---|
| committer | n0n4m3 <none@none> | 2009-12-24 10:20:15 +0100 |
| commit | 250a00cc1c91d2df2b6c4f72a2ad322b46fed783 (patch) | |
| tree | eab0216df4c91777747e866ed4525c9fbc7a037f /src/shared/Timer.h | |
| parent | acdc4ca15b69c84197f867192328829904646a66 (diff) | |
Temporary revert 6743 commit. I fix this patch across 1-2 days.
--HG--
branch : trunk
Diffstat (limited to 'src/shared/Timer.h')
| -rw-r--r-- | src/shared/Timer.h | 79 |
1 files changed, 75 insertions, 4 deletions
diff --git a/src/shared/Timer.h b/src/shared/Timer.h index d21407b8e42..46bba5475bc 100644 --- a/src/shared/Timer.h +++ b/src/shared/Timer.h @@ -18,13 +18,21 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ -#ifndef _TIMER_H -#define _TIMER_H +#ifndef TRINITY_TIMER_H +#define TRINITY_TIMER_H -#include "Platform/Define.h" +#include "Platform/CompilerDefs.h" -#if (PLATFORM != PLATFORM_WINDOWS) +#if PLATFORM == PLATFORM_WINDOWS +# include <ace/config-all.h> +# include <mmsystem.h> +# include <time.h> +#else +# if defined(__APPLE_CC__) +# include <time.h> +# endif # include <sys/time.h> +# include <sys/timeb.h> #endif #if PLATFORM == PLATFORM_WINDOWS @@ -48,4 +56,67 @@ inline uint32 getMSTimeDiff(uint32 oldMSTime, uint32 newMSTime) return newMSTime - oldMSTime; } +class IntervalTimer +{ + public: + IntervalTimer() : _interval(0), _current(0) {} + + void Update(time_t diff) { _current += diff; if(_current<0) _current=0;} + bool Passed() { return _current >= _interval; } + void Reset() { if(_current >= _interval) _current -= _interval; } + + void SetCurrent(time_t current) { _current = current; } + void SetInterval(time_t interval) { _interval = interval; } + time_t GetInterval() const { return _interval; } + time_t GetCurrent() const { return _current; } + + private: + time_t _interval; + time_t _current; +}; + +struct TimeTracker +{ + TimeTracker(time_t expiry) : i_expiryTime(expiry) {} + void Update(time_t diff) { i_expiryTime -= diff; } + bool Passed(void) const { return (i_expiryTime <= 0); } + void Reset(time_t interval) { i_expiryTime = interval; } + time_t GetExpiry(void) const { return i_expiryTime; } + time_t i_expiryTime; +}; + +struct TimeTrackerSmall +{ + TimeTrackerSmall(int32 expiry) : i_expiryTime(expiry) {} + void Update(int32 diff) { i_expiryTime -= diff; } + bool Passed(void) const { return (i_expiryTime <= 0); } + void Reset(int32 interval) { i_expiryTime = interval; } + int32 GetExpiry(void) const { return i_expiryTime; } + int32 i_expiryTime; +}; + +struct PeriodicTimer +{ + PeriodicTimer(int32 period, int32 start_time) : + i_expireTime(start_time), i_period(period) {} + + bool Update(const uint32 &diff) + { + if((i_expireTime -= diff) > 0) + return false; + + i_expireTime += i_period > diff ? i_period : diff; + return true; + } + + void SetPeriodic(int32 period, int32 start_time) + { + i_expireTime=start_time, i_period=period; + } + + int32 i_period; + int32 i_expireTime; +}; + #endif + |
