aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Maps/MapManager.cpp
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2024-03-14 20:32:03 +0100
committerShauren <shauren.trinity@gmail.com>2024-03-14 20:32:03 +0100
commit783f9c0ea38da35c328affa27ac4cf6b7bfd8bd8 (patch)
tree23947e9b265d4e7f20f757f21740dd10bac59f5b /src/server/game/Maps/MapManager.cpp
parent6224036efd9e6173f4650d7b7c0a31319a3dad7a (diff)
Core/Scripts: Removed script calls from constructors and destructors
Diffstat (limited to 'src/server/game/Maps/MapManager.cpp')
-rw-r--r--src/server/game/Maps/MapManager.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/server/game/Maps/MapManager.cpp b/src/server/game/Maps/MapManager.cpp
index 6b1845a247b..59a9a269142 100644
--- a/src/server/game/Maps/MapManager.cpp
+++ b/src/server/game/Maps/MapManager.cpp
@@ -16,6 +16,7 @@
*/
#include "MapManager.h"
+#include "BattlefieldMgr.h"
#include "Battleground.h"
#include "Containers.h"
#include "DatabaseEnv.h"
@@ -25,6 +26,7 @@
#include "InstanceLockMgr.h"
#include "Log.h"
#include "Map.h"
+#include "OutdoorPvPMgr.h"
#include "Player.h"
#include "ScenarioMgr.h"
#include "ScriptMgr.h"
@@ -253,6 +255,10 @@ Map* MapManager::CreateMap(uint32 mapId, Player* player)
{
ptr.reset(map);
map->SetWeakPtr(ptr);
+
+ sScriptMgr->OnCreateMap(map);
+ sOutdoorPvPMgr->CreateOutdoorPvPForMap(map);
+ sBattlefieldMgr->CreateBattlefieldsForMap(map);
}
}
@@ -349,6 +355,10 @@ bool MapManager::DestroyMap(Map* map)
if (map->HavePlayers())
return false;
+ sOutdoorPvPMgr->DestroyOutdoorPvPForMap(map);
+ sBattlefieldMgr->DestroyBattlefieldsForMap(map);
+ sScriptMgr->OnDestroyMap(map);
+
map->UnloadAll();
// Free up the instance id and allow it to be reused for normal dungeons, bgs and arenas
@@ -368,8 +378,14 @@ void MapManager::UnloadAll()
{
// first unload maps
for (auto iter = i_maps.begin(); iter != i_maps.end(); ++iter)
+ {
iter->second->UnloadAll();
+ sOutdoorPvPMgr->DestroyOutdoorPvPForMap(iter->second.get());
+ sBattlefieldMgr->DestroyBattlefieldsForMap(iter->second.get());
+ sScriptMgr->OnDestroyMap(iter->second.get());
+ }
+
// then delete them
i_maps.clear();