Fixed bug at17357 (FireStorm)

This commit is contained in:
David Anderson 2005-08-17 18:16:26 +00:00
parent 593e013572
commit 661f6c9851

View File

@ -53,8 +53,14 @@ void CTaskMngr::CTask::set(CPluginMngr::CPlugin *pPlugin, int iFunc, int iFlags,
m_iId = iId; m_iId = iId;
m_fBase = fBase; m_fBase = fBase;
m_iRepeat = (iFlags & 1) ? iRepeat : 0; if (iFlags & 2)
m_bLoop = (iFlags & 2) ? true : false; {
m_bLoop = true;
m_iRepeat = -1;
} else if (iFlags & 1) {
m_bLoop = true;
m_iRepeat = iRepeat;
}
m_bAfterStart = (iFlags & 4) ? true : false; m_bAfterStart = (iFlags & 4) ? true : false;
m_bBeforeEnd = (iFlags & 8) ? true : false; m_bBeforeEnd = (iFlags & 8) ? true : false;
@ -118,6 +124,7 @@ void CTaskMngr::CTask::resetNextExecTime(float fCurrentTime)
void CTaskMngr::CTask::executeIfRequired(float fCurrentTime, float fTimeLimit, float fTimeLeft) void CTaskMngr::CTask::executeIfRequired(float fCurrentTime, float fTimeLimit, float fTimeLeft)
{ {
bool execute=false; bool execute=false;
bool done=false;
if (m_bAfterStart) if (m_bAfterStart)
{ {
if (fCurrentTime - fTimeLeft + 1.0f >= m_fBase) if (fCurrentTime - fTimeLeft + 1.0f >= m_fBase)
@ -127,31 +134,41 @@ void CTaskMngr::CTask::executeIfRequired(float fCurrentTime, float fTimeLimit, f
{ {
if (fTimeLimit != 0.0f && (fTimeLeft + fTimeLimit * 60.0f) - fCurrentTime - 1.0f <= m_fBase) if (fTimeLimit != 0.0f && (fTimeLeft + fTimeLimit * 60.0f) - fCurrentTime - 1.0f <= m_fBase)
execute = true; execute = true;
} } else if (m_fNextExecTime <= fCurrentTime) {
else if (m_fNextExecTime <= fCurrentTime)
execute = true; execute = true;
}
if (execute) if (execute)
{ {
if (m_iParamLen) // call with parameters //only bother calling if we have something to call
if ( !(m_bLoop && !m_iRepeat) )
{ {
cell arr = prepareCellArray(m_pParams, m_iParamLen); if (m_iParamLen) // call with parameters
executeForwards(m_iFunc, arr, m_iId); {
} else { cell arr = prepareCellArray(m_pParams, m_iParamLen);
executeForwards(m_iFunc, m_iId); executeForwards(m_iFunc, arr, m_iId);
} else {
executeForwards(m_iFunc, m_iId);
}
} }
if (isFree()) if (isFree())
return; return;
// set new exec time OR remove the task if needed // set new exec time OR remove the task if needed
if (m_bLoop || (m_iRepeat-- > 0)) if (m_bLoop)
{ {
m_fNextExecTime += m_fBase; if (m_iRepeat != -1 && --m_iRepeat <= 0)
done = true;
} else {
done = true;
} }
else
if (done)
{ {
clear(); // hamster clear();
} else {
m_fNextExecTime += m_fBase;
} }
} }
} }