aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xengines/pegasus/timers.cpp16
-rwxr-xr-xengines/pegasus/timers.h2
2 files changed, 10 insertions, 8 deletions
diff --git a/engines/pegasus/timers.cpp b/engines/pegasus/timers.cpp
index 1699867314..ab0e4da31d 100755
--- a/engines/pegasus/timers.cpp
+++ b/engines/pegasus/timers.cpp
@@ -223,17 +223,19 @@ void TimeBase::checkCallBacks() {
// TODO: Update the slaves?
+ Common::Rational time = getTime();
+
// Check if we've triggered any callbacks
for (TimeBaseCallBack *runner = _callBackList; runner != 0; runner = runner->_nextCallBack) {
if (runner->_type == kCallBackAtTime && runner->_trigger == kTriggerTimeFwd) {
- if (_time >= (runner->_param2 * _preferredScale / runner->_param3) && getRate() > 0)
+ if (time >= (runner->_param2 * _preferredScale / runner->_param3) && getRate() > 0)
runner->callBack();
} else if (runner->_type == kCallBackAtExtremes) {
if (runner->_trigger == kTriggerAtStop) {
- if (_time == stopTime)
+ if (time == stopTime)
runner->callBack();
} else if (runner->_trigger == kTriggerAtStart) {
- if (_time == startTime)
+ if (time == startTime)
runner->callBack();
}
}
@@ -241,10 +243,10 @@ void TimeBase::checkCallBacks() {
// Loop if necessary
if (getFlags() & kLoopTimeBase) {
- if (_time == startTime)
- _time = stopTime;
- else if (_time == stopTime)
- _time = startTime;
+ if (time == startTime)
+ setTime(_stopTime, _stopScale);
+ else if (time == stopTime)
+ setTime(_startTime, _startScale);
}
}
diff --git a/engines/pegasus/timers.h b/engines/pegasus/timers.h
index 04dd235dae..a40a2c179b 100755
--- a/engines/pegasus/timers.h
+++ b/engines/pegasus/timers.h
@@ -102,7 +102,7 @@ public:
void disposeAllCallBacks();
// ScummVM's API additions (to replace the need for actual timers)
- void checkCallBacks();
+ virtual void checkCallBacks();
protected:
void addCallBack(TimeBaseCallBack *);