aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Maps/Map.cpp
diff options
context:
space:
mode:
authorCarbenium <carbenium@outlook.com>2015-09-23 22:32:03 +0200
committerCarbenium <carbenium@outlook.com>2015-09-25 00:22:05 +0200
commit512c2ab83cbdbcf7baf480148330cb9a68b26709 (patch)
treef30b8850fceb12a2bd6fa2ff7112462eac09451b /src/server/game/Maps/Map.cpp
parenta53a8fff98e5fafa82f87729ee3f68011667099c (diff)
Merge pull request #15538 from pete318/combat_bug
Combat with distant creatures (Mk II) (cherry picked from commit a40d855337bd29f55d898fb5213af92abd5b43a1)
Diffstat (limited to 'src/server/game/Maps/Map.cpp')
-rw-r--r--src/server/game/Maps/Map.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/server/game/Maps/Map.cpp b/src/server/game/Maps/Map.cpp
index fb0dc751da7..ccfd3ce33f7 100644
--- a/src/server/game/Maps/Map.cpp
+++ b/src/server/game/Maps/Map.cpp
@@ -689,6 +689,26 @@ void Map::Update(const uint32 t_diff)
player->Update(t_diff);
VisitNearbyCellsOf(player, grid_object_update, world_object_update);
+
+ // Handle updates for creatures in combat with player and are more than 60 yards away
+ if (player->IsInCombat())
+ {
+ std::vector<Creature*> updateList;
+ HostileReference* ref = player->getHostileRefManager().getFirst();
+
+ while (ref)
+ {
+ if (Unit* unit = ref->GetSource()->GetOwner())
+ if (unit->ToCreature() && unit->GetMapId() == player->GetMapId() && !unit->IsWithinDistInMap(player, GetVisibilityRange(), false))
+ updateList.push_back(unit->ToCreature());
+
+ ref = ref->next();
+ }
+
+ // Process deferred update list for player
+ for (Creature* c : updateList)
+ VisitNearbyCellsOf(c, grid_object_update, world_object_update);
+ }
}
// non-player active objects, increasing iterator in the loop in case of object removal