mirror of
https://github.com/araxiaonline/TrinityCore.git
synced 2026-06-16 21:20:01 -04:00
Conflicts: src/server/game/Achievements/AchievementMgr.cpp src/server/game/Battlefield/Battlefield.h src/server/game/Battlegrounds/ArenaScore.h src/server/game/Battlegrounds/ArenaTeam.cpp src/server/game/Battlegrounds/ArenaTeam.h src/server/game/Battlegrounds/ArenaTeamMgr.cpp src/server/game/Battlegrounds/BattlegroundMgr.cpp src/server/game/Battlegrounds/BattlegroundMgr.h src/server/game/Battlegrounds/BattlegroundQueue.h src/server/game/Battlegrounds/BattlegroundScore.h src/server/game/Battlegrounds/Zones/BattlegroundAB.h src/server/game/Battlegrounds/Zones/BattlegroundAV.h src/server/game/Battlegrounds/Zones/BattlegroundEY.h src/server/game/Battlegrounds/Zones/BattlegroundIC.h src/server/game/Battlegrounds/Zones/BattlegroundSA.h src/server/game/Battlegrounds/Zones/BattlegroundWS.h src/server/game/DungeonFinding/LFG.h src/server/game/DungeonFinding/LFGMgr.cpp src/server/game/DungeonFinding/LFGMgr.h src/server/game/DungeonFinding/LFGQueue.cpp src/server/game/DungeonFinding/LFGQueue.h src/server/game/Entities/Corpse/Corpse.cpp src/server/game/Entities/Creature/Creature.cpp src/server/game/Entities/Creature/GossipDef.cpp src/server/game/Entities/Creature/GossipDef.h src/server/game/Entities/Creature/TemporarySummon.cpp src/server/game/Entities/DynamicObject/DynamicObject.cpp src/server/game/Entities/Object/Object.cpp src/server/game/Entities/Object/Object.h src/server/game/Entities/Object/ObjectDefines.h src/server/game/Entities/Object/Updates/UpdateData.cpp src/server/game/Entities/Player/Player.cpp src/server/game/Entities/Player/Player.h src/server/game/Entities/Unit/Unit.cpp src/server/game/Entities/Unit/Unit.h src/server/game/Globals/ObjectAccessor.cpp src/server/game/Globals/ObjectAccessor.h src/server/game/Globals/ObjectMgr.cpp src/server/game/Groups/Group.cpp src/server/game/Groups/Group.h src/server/game/Guilds/Guild.cpp src/server/game/Guilds/Guild.h src/server/game/Handlers/AuctionHouseHandler.cpp src/server/game/Handlers/BattleGroundHandler.cpp src/server/game/Handlers/CalendarHandler.cpp src/server/game/Handlers/CharacterHandler.cpp src/server/game/Handlers/ChatHandler.cpp src/server/game/Handlers/GroupHandler.cpp src/server/game/Handlers/GuildHandler.cpp src/server/game/Handlers/ItemHandler.cpp src/server/game/Handlers/LFGHandler.cpp src/server/game/Handlers/MailHandler.cpp src/server/game/Handlers/MiscHandler.cpp src/server/game/Handlers/MovementHandler.cpp src/server/game/Handlers/NPCHandler.cpp src/server/game/Handlers/PetHandler.cpp src/server/game/Handlers/QueryHandler.cpp src/server/game/Handlers/QuestHandler.cpp src/server/game/Handlers/TradeHandler.cpp src/server/game/Handlers/VehicleHandler.cpp src/server/game/Movement/Spline/MoveSplineInit.cpp src/server/game/Server/WorldSession.cpp src/server/game/Server/WorldSession.h src/server/game/Spells/Spell.cpp src/server/scripts/Commands/cs_debug.cpp src/server/scripts/Commands/cs_gm.cpp src/server/scripts/Commands/cs_misc.cpp src/server/scripts/Commands/cs_modify.cpp src/server/scripts/Commands/cs_reset.cpp src/server/scripts/EasternKingdoms/ZulAman/boss_akilzon.cpp src/server/scripts/EasternKingdoms/ZulAman/boss_halazzi.cpp src/server/scripts/EasternKingdoms/ZulAman/boss_hexlord.cpp src/server/scripts/EasternKingdoms/ZulAman/boss_janalai.cpp src/server/scripts/EasternKingdoms/ZulAman/boss_zuljin.cpp src/server/scripts/EasternKingdoms/ZulAman/instance_zulaman.cpp src/server/scripts/EasternKingdoms/ZulAman/zulaman.cpp src/server/scripts/EasternKingdoms/ZulGurub/boss_arlokk.cpp src/server/scripts/EasternKingdoms/ZulGurub/boss_jindo.cpp src/server/scripts/EasternKingdoms/ZulGurub/boss_mandokir.cpp src/server/scripts/EasternKingdoms/ZulGurub/boss_thekal.cpp src/server/scripts/EasternKingdoms/ZulGurub/instance_zulgurub.cpp src/server/scripts/EasternKingdoms/zone_silverpine_forest.cpp src/server/scripts/EasternKingdoms/zone_stormwind_city.cpp src/server/scripts/EasternKingdoms/zone_swamp_of_sorrows.cpp src/server/scripts/EasternKingdoms/zone_tirisfal_glades.cpp src/server/scripts/Kalimdor/zone_azshara.cpp src/server/scripts/Kalimdor/zone_durotar.cpp src/server/scripts/Kalimdor/zone_moonglade.cpp src/server/scripts/Kalimdor/zone_orgrimmar.cpp src/server/scripts/Kalimdor/zone_ungoro_crater.cpp src/server/scripts/Northrend/FrozenHalls/HallsOfReflection/halls_of_reflection.cpp src/server/scripts/Northrend/IcecrownCitadel/boss_the_lich_king.cpp src/server/scripts/Northrend/Naxxramas/boss_kelthuzad.cpp src/server/scripts/OutdoorPvP/OutdoorPvPEP.cpp src/server/scripts/Spells/spell_dk.cpp src/server/scripts/Spells/spell_generic.cpp src/server/shared/Packets/ByteBuffer.h
268 lines
9.2 KiB
C++
268 lines
9.2 KiB
C++
/*
|
|
* Copyright (C) 2008-2014 TrinityCore <http://www.trinitycore.org/>
|
|
* Copyright (C) 2005-2009 MaNGOS <http://getmangos.com/>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; either version 2 of the License, or (at your
|
|
* option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "ObjectGridLoader.h"
|
|
#include "ObjectAccessor.h"
|
|
#include "ObjectMgr.h"
|
|
#include "Creature.h"
|
|
#include "Vehicle.h"
|
|
#include "GameObject.h"
|
|
#include "DynamicObject.h"
|
|
#include "Corpse.h"
|
|
#include "AreaTrigger.h"
|
|
#include "World.h"
|
|
#include "CellImpl.h"
|
|
#include "CreatureAI.h"
|
|
|
|
void ObjectGridEvacuator::Visit(CreatureMapType &m)
|
|
{
|
|
// creature in unloading grid can have respawn point in another grid
|
|
// if it will be unloaded then it will not respawn in original grid until unload/load original grid
|
|
// move to respawn point to prevent this case. For player view in respawn grid this will be normal respawn.
|
|
for (CreatureMapType::iterator iter = m.begin(); iter != m.end();)
|
|
{
|
|
Creature* c = iter->GetSource();
|
|
++iter;
|
|
|
|
ASSERT(!c->IsPet() && "ObjectGridRespawnMover must not be called for pets");
|
|
c->GetMap()->CreatureRespawnRelocation(c, true);
|
|
}
|
|
}
|
|
|
|
void ObjectGridEvacuator::Visit(GameObjectMapType &m)
|
|
{
|
|
// gameobject in unloading grid can have respawn point in another grid
|
|
// if it will be unloaded then it will not respawn in original grid until unload/load original grid
|
|
// move to respawn point to prevent this case. For player view in respawn grid this will be normal respawn.
|
|
for (GameObjectMapType::iterator iter = m.begin(); iter != m.end();)
|
|
{
|
|
GameObject* go = iter->GetSource();
|
|
++iter;
|
|
|
|
go->GetMap()->GameObjectRespawnRelocation(go, true);
|
|
}
|
|
}
|
|
|
|
// for loading world object at grid loading (Corpses)
|
|
/// @todo to implement npc on transport, also need to load npcs at grid loading
|
|
class ObjectWorldLoader
|
|
{
|
|
public:
|
|
explicit ObjectWorldLoader(ObjectGridLoader& gloader)
|
|
: i_cell(gloader.i_cell), i_map(gloader.i_map), i_corpses (0)
|
|
{ }
|
|
|
|
void Visit(CorpseMapType &m);
|
|
|
|
template<class T> void Visit(GridRefManager<T>&) { }
|
|
|
|
private:
|
|
Cell i_cell;
|
|
Map* i_map;
|
|
public:
|
|
uint32 i_corpses;
|
|
};
|
|
|
|
template<class T> void ObjectGridLoader::SetObjectCell(T* /*obj*/, CellCoord const& /*cellCoord*/) { }
|
|
|
|
template<> void ObjectGridLoader::SetObjectCell(Creature* obj, CellCoord const& cellCoord)
|
|
{
|
|
Cell cell(cellCoord);
|
|
obj->SetCurrentCell(cell);
|
|
}
|
|
|
|
template<> void ObjectGridLoader::SetObjectCell(GameObject* obj, CellCoord const& cellCoord)
|
|
{
|
|
Cell cell(cellCoord);
|
|
obj->SetCurrentCell(cell);
|
|
}
|
|
|
|
template <class T>
|
|
void AddObjectHelper(CellCoord &cell, GridRefManager<T> &m, uint32 &count, Map* /*map*/, T *obj)
|
|
{
|
|
obj->AddToGrid(m);
|
|
ObjectGridLoader::SetObjectCell(obj, cell);
|
|
obj->AddToWorld();
|
|
++count;
|
|
}
|
|
|
|
template <>
|
|
void AddObjectHelper(CellCoord &cell, CreatureMapType &m, uint32 &count, Map* map, Creature *obj)
|
|
{
|
|
obj->AddToGrid(m);
|
|
ObjectGridLoader::SetObjectCell(obj, cell);
|
|
obj->AddToWorld();
|
|
if (obj->isActiveObject())
|
|
map->AddToActive(obj);
|
|
|
|
++count;
|
|
}
|
|
|
|
template <class T>
|
|
void LoadHelper(CellGuidSet const& guid_set, CellCoord &cell, GridRefManager<T> &m, uint32 &count, Map* map)
|
|
{
|
|
for (CellGuidSet::const_iterator i_guid = guid_set.begin(); i_guid != guid_set.end(); ++i_guid)
|
|
{
|
|
T* obj = new T;
|
|
uint32 guid = *i_guid;
|
|
//TC_LOG_INFO("misc", "DEBUG: LoadHelper from table: %s for (guid: %u) Loading", table, guid);
|
|
if (!obj->LoadFromDB(guid, map))
|
|
{
|
|
delete obj;
|
|
continue;
|
|
}
|
|
|
|
AddObjectHelper(cell, m, count, map, obj);
|
|
}
|
|
}
|
|
|
|
void LoadHelper(CellCorpseSet const& cell_corpses, CellCoord &cell, CorpseMapType &m, uint32 &count, Map* map)
|
|
{
|
|
if (cell_corpses.empty())
|
|
return;
|
|
|
|
for (CellCorpseSet::const_iterator itr = cell_corpses.begin(); itr != cell_corpses.end(); ++itr)
|
|
{
|
|
if (itr->second != map->GetInstanceId())
|
|
continue;
|
|
|
|
ObjectGuid player_guid(HIGHGUID_PLAYER, itr->first);
|
|
|
|
Corpse* obj = sObjectAccessor->GetCorpseForPlayerGUID(player_guid);
|
|
if (!obj)
|
|
continue;
|
|
|
|
/// @todo this is a hack
|
|
// corpse's map should be reset when the map is unloaded
|
|
// but it may still exist when the grid is unloaded but map is not
|
|
// in that case map == currMap
|
|
obj->SetMap(map);
|
|
|
|
if (obj->IsInGrid())
|
|
{
|
|
obj->AddToWorld();
|
|
continue;
|
|
}
|
|
|
|
AddObjectHelper(cell, m, count, map, obj);
|
|
}
|
|
}
|
|
|
|
void ObjectGridLoader::Visit(GameObjectMapType &m)
|
|
{
|
|
CellCoord cellCoord = i_cell.GetCellCoord();
|
|
CellObjectGuids const& cell_guids = sObjectMgr->GetCellObjectGuids(i_map->GetId(), i_map->GetSpawnMode(), cellCoord.GetId());
|
|
LoadHelper(cell_guids.gameobjects, cellCoord, m, i_gameObjects, i_map);
|
|
}
|
|
|
|
void ObjectGridLoader::Visit(CreatureMapType &m)
|
|
{
|
|
CellCoord cellCoord = i_cell.GetCellCoord();
|
|
CellObjectGuids const& cell_guids = sObjectMgr->GetCellObjectGuids(i_map->GetId(), i_map->GetSpawnMode(), cellCoord.GetId());
|
|
LoadHelper(cell_guids.creatures, cellCoord, m, i_creatures, i_map);
|
|
}
|
|
|
|
void ObjectWorldLoader::Visit(CorpseMapType &m)
|
|
{
|
|
CellCoord cellCoord = i_cell.GetCellCoord();
|
|
// corpses are always added to spawn mode 0 and they are spawned by their instance id
|
|
CellObjectGuids const& cell_guids = sObjectMgr->GetCellObjectGuids(i_map->GetId(), 0, cellCoord.GetId());
|
|
LoadHelper(cell_guids.corpses, cellCoord, m, i_corpses, i_map);
|
|
}
|
|
|
|
void ObjectGridLoader::LoadN(void)
|
|
{
|
|
i_gameObjects = 0; i_creatures = 0; i_corpses = 0;
|
|
i_cell.data.Part.cell_y = 0;
|
|
for (unsigned int x=0; x < MAX_NUMBER_OF_CELLS; ++x)
|
|
{
|
|
i_cell.data.Part.cell_x = x;
|
|
for (unsigned int y=0; y < MAX_NUMBER_OF_CELLS; ++y)
|
|
{
|
|
i_cell.data.Part.cell_y = y;
|
|
|
|
//Load creatures and game objects
|
|
{
|
|
TypeContainerVisitor<ObjectGridLoader, GridTypeMapContainer> visitor(*this);
|
|
i_grid.VisitGrid(x, y, visitor);
|
|
}
|
|
|
|
//Load corpses (not bones)
|
|
{
|
|
ObjectWorldLoader worker(*this);
|
|
TypeContainerVisitor<ObjectWorldLoader, WorldTypeMapContainer> visitor(worker);
|
|
i_grid.VisitGrid(x, y, visitor);
|
|
i_corpses += worker.i_corpses;
|
|
}
|
|
}
|
|
}
|
|
TC_LOG_DEBUG("maps", "%u GameObjects, %u Creatures, and %u Corpses/Bones loaded for grid %u on map %u", i_gameObjects, i_creatures, i_corpses, i_grid.GetGridId(), i_map->GetId());
|
|
}
|
|
|
|
template<class T>
|
|
void ObjectGridUnloader::Visit(GridRefManager<T> &m)
|
|
{
|
|
while (!m.isEmpty())
|
|
{
|
|
T *obj = m.getFirst()->GetSource();
|
|
// if option set then object already saved at this moment
|
|
if (!sWorld->getBoolConfig(CONFIG_SAVE_RESPAWN_TIME_IMMEDIATELY))
|
|
obj->SaveRespawnTime();
|
|
//Some creatures may summon other temp summons in CleanupsBeforeDelete()
|
|
//So we need this even after cleaner (maybe we can remove cleaner)
|
|
//Example: Flame Leviathan Turret 33139 is summoned when a creature is deleted
|
|
/// @todo Check if that script has the correct logic. Do we really need to summons something before deleting?
|
|
obj->CleanupsBeforeDelete();
|
|
///- object will get delinked from the manager when deleted
|
|
delete obj;
|
|
}
|
|
}
|
|
|
|
void ObjectGridStoper::Visit(CreatureMapType &m)
|
|
{
|
|
// stop any fights at grid de-activation and remove dynobjects created at cast by creatures
|
|
for (CreatureMapType::iterator iter = m.begin(); iter != m.end(); ++iter)
|
|
{
|
|
iter->GetSource()->RemoveAllDynObjects();
|
|
if (iter->GetSource()->IsInCombat())
|
|
{
|
|
iter->GetSource()->CombatStop();
|
|
iter->GetSource()->DeleteThreatList();
|
|
iter->GetSource()->AI()->EnterEvadeMode();
|
|
}
|
|
}
|
|
}
|
|
|
|
template<class T>
|
|
void ObjectGridCleaner::Visit(GridRefManager<T> &m)
|
|
{
|
|
for (typename GridRefManager<T>::iterator iter = m.begin(); iter != m.end(); ++iter)
|
|
iter->GetSource()->CleanupsBeforeDelete();
|
|
}
|
|
|
|
template void ObjectGridUnloader::Visit(CreatureMapType &);
|
|
template void ObjectGridUnloader::Visit(GameObjectMapType &);
|
|
template void ObjectGridUnloader::Visit(DynamicObjectMapType &);
|
|
template void ObjectGridUnloader::Visit(CorpseMapType &);
|
|
template void ObjectGridUnloader::Visit(AreaTriggerMapType &);
|
|
template void ObjectGridCleaner::Visit(CreatureMapType &);
|
|
template void ObjectGridCleaner::Visit<GameObject>(GameObjectMapType &);
|
|
template void ObjectGridCleaner::Visit<DynamicObject>(DynamicObjectMapType &);
|
|
template void ObjectGridCleaner::Visit<Corpse>(CorpseMapType &);
|
|
template void ObjectGridCleaner::Visit<AreaTrigger>(AreaTriggerMapType &);
|