aboutsummaryrefslogtreecommitdiff
path: root/src/shared/Timer.h
diff options
context:
space:
mode:
authorn0n4m3 <none@none>2009-12-24 10:20:15 +0100
committern0n4m3 <none@none>2009-12-24 10:20:15 +0100
commit250a00cc1c91d2df2b6c4f72a2ad322b46fed783 (patch)
treeeab0216df4c91777747e866ed4525c9fbc7a037f /src/shared/Timer.h
parentacdc4ca15b69c84197f867192328829904646a66 (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.h79
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
+