diff options
Diffstat (limited to 'src/server')
-rw-r--r-- | src/server/game/AI/SmartScripts/SmartAI.cpp | 179 | ||||
-rw-r--r-- | src/server/game/AI/SmartScripts/SmartAI.h | 6 |
2 files changed, 96 insertions, 89 deletions
diff --git a/src/server/game/AI/SmartScripts/SmartAI.cpp b/src/server/game/AI/SmartScripts/SmartAI.cpp index 6bff5022b70..24719902659 100644 --- a/src/server/game/AI/SmartScripts/SmartAI.cpp +++ b/src/server/game/AI/SmartScripts/SmartAI.cpp @@ -42,24 +42,6 @@ bool SmartAI::IsAIControlled() const return !mIsCharmed; } -void SmartAI::UpdateDespawn(uint32 diff) -{ - if (mDespawnState <= 1 || mDespawnState > 3) - return; - - if (mDespawnTime < diff) - { - if (mDespawnState == 2) - { - me->SetVisible(false); - mDespawnTime = 5000; - mDespawnState++; - } - else - me->DespawnOrUnsummon(); - } else mDespawnTime -= diff; -} - void SmartAI::StartPath(bool run/* = false*/, uint32 pathId/* = 0*/, bool repeat/* = false*/, Unit* invoker/* = nullptr*/, uint32 nodeId/* = 1*/) { if (me->IsInCombat()) // no wp movement in combat @@ -296,81 +278,16 @@ void SmartAI::ReturnToLastOOCPos() me->GetMotionMaster()->MovePoint(SMART_ESCORT_LAST_OOC_POINT, me->GetHomePosition()); } -void SmartAI::UpdatePath(const uint32 diff) -{ - if (!HasEscortState(SMART_ESCORT_ESCORTING)) - return; - - if (_escortInvokerCheckTimer < diff) - { - if (!IsEscortInvokerInRange()) - { - StopPath(0, mEscortQuestID, true); - - // allow to properly hook out of range despawn action, which in most cases should perform the same operation as dying - GetScript()->ProcessEventsFor(SMART_EVENT_DEATH, me); - me->DespawnOrUnsummon(); - return; - } - _escortInvokerCheckTimer = 1000; - } - else - _escortInvokerCheckTimer -= diff; - - // handle pause - if (HasEscortState(SMART_ESCORT_PAUSED) && (_waypointReached || _waypointPauseForced)) - { - if (_waypointPauseTimer <= diff) - { - if (!me->IsInCombat() && !HasEscortState(SMART_ESCORT_RETURNING)) - ResumePath(); - } - else - _waypointPauseTimer -= diff; - } - else if (_waypointPathEnded) // end path - { - _waypointPathEnded = false; - StopPath(); - return; - } - - if (HasEscortState(SMART_ESCORT_RETURNING)) - { - if (_OOCReached) // reached OOC WP - { - _OOCReached = false; - RemoveEscortState(SMART_ESCORT_RETURNING); - if (!HasEscortState(SMART_ESCORT_PAUSED)) - ResumePath(); - } - } -} - void SmartAI::UpdateAI(uint32 diff) { CheckConditions(diff); + GetScript()->OnUpdate(diff); + UpdatePath(diff); + UpdateFollow(diff); UpdateDespawn(diff); - /// @todo move to void - if (mFollowGuid) - { - if (mFollowArrivedTimer < diff) - { - if (me->FindNearestCreature(mFollowArrivedEntry, INTERACTION_DISTANCE, true)) - { - StopFollow(true); - return; - } - - mFollowArrivedTimer = 1000; - } - else - mFollowArrivedTimer -= diff; - } - if (!IsAIControlled()) return; @@ -969,6 +886,96 @@ void SmartAI::CheckConditions(uint32 diff) mConditionsTimer -= diff; } +void SmartAI::UpdatePath(uint32 diff) +{ + if (!HasEscortState(SMART_ESCORT_ESCORTING)) + return; + + if (_escortInvokerCheckTimer < diff) + { + if (!IsEscortInvokerInRange()) + { + StopPath(0, mEscortQuestID, true); + + // allow to properly hook out of range despawn action, which in most cases should perform the same operation as dying + GetScript()->ProcessEventsFor(SMART_EVENT_DEATH, me); + me->DespawnOrUnsummon(); + return; + } + _escortInvokerCheckTimer = 1000; + } + else + _escortInvokerCheckTimer -= diff; + + // handle pause + if (HasEscortState(SMART_ESCORT_PAUSED) && (_waypointReached || _waypointPauseForced)) + { + if (_waypointPauseTimer <= diff) + { + if (!me->IsInCombat() && !HasEscortState(SMART_ESCORT_RETURNING)) + ResumePath(); + } + else + _waypointPauseTimer -= diff; + } + else if (_waypointPathEnded) // end path + { + _waypointPathEnded = false; + StopPath(); + return; + } + + if (HasEscortState(SMART_ESCORT_RETURNING)) + { + if (_OOCReached) // reached OOC WP + { + _OOCReached = false; + RemoveEscortState(SMART_ESCORT_RETURNING); + if (!HasEscortState(SMART_ESCORT_PAUSED)) + ResumePath(); + } + } +} + +void SmartAI::UpdateFollow(uint32 diff) +{ + if (mFollowGuid) + { + if (mFollowArrivedTimer < diff) + { + if (me->FindNearestCreature(mFollowArrivedEntry, INTERACTION_DISTANCE, true)) + { + StopFollow(true); + return; + } + + mFollowArrivedTimer = 1000; + } + else + mFollowArrivedTimer -= diff; + } +} + +void SmartAI::UpdateDespawn(uint32 diff) +{ + if (mDespawnState <= 1 || mDespawnState > 3) + return; + + if (mDespawnTime < diff) + { + if (mDespawnState == 2) + { + me->SetVisible(false); + mDespawnTime = 5000; + mDespawnState++; + } + else + me->DespawnOrUnsummon(); + } + else + mDespawnTime -= diff; +} + void SmartGameObjectAI::UpdateAI(uint32 diff) { GetScript()->OnUpdate(diff); diff --git a/src/server/game/AI/SmartScripts/SmartAI.h b/src/server/game/AI/SmartScripts/SmartAI.h index d967a7512cc..ecf9aaeb97a 100644 --- a/src/server/game/AI/SmartScripts/SmartAI.h +++ b/src/server/game/AI/SmartScripts/SmartAI.h @@ -201,10 +201,10 @@ class TC_GAME_API SmartAI : public CreatureAI private: bool AssistPlayerInCombatAgainst(Unit* who); void ReturnToLastOOCPos(); - void UpdatePath(const uint32 diff); - void UpdateDespawn(uint32 diff); - // Vehicle conditions void CheckConditions(uint32 diff); + void UpdatePath(uint32 diff); + void UpdateFollow(uint32 diff); + void UpdateDespawn(uint32 diff); SmartScript mScript; |