diff --git a/sql/updates/world/3.3.5/2020_06_14_00_world.sql b/sql/updates/world/3.3.5/2020_06_14_00_world.sql new file mode 100644 index 0000000000..47a04e605c --- /dev/null +++ b/sql/updates/world/3.3.5/2020_06_14_00_world.sql @@ -0,0 +1,6 @@ +-- +DELETE FROM `command` WHERE `name`='debug objectcount'; +INSERT INTO `command` (`name`,`permission`,`help`) VALUES +('debug objectcount',300,'Syntax: .debug objectcount +Shows the number of Creatures and GameObjects for the specified map id or for all maps if none is specified +'); diff --git a/src/server/scripts/Commands/cs_debug.cpp b/src/server/scripts/Commands/cs_debug.cpp index a6ba2cc64a..4eeae6a907 100644 --- a/src/server/scripts/Commands/cs_debug.cpp +++ b/src/server/scripts/Commands/cs_debug.cpp @@ -120,6 +120,7 @@ public: { "dummy", rbac::RBAC_PERM_COMMAND_DEBUG_DUMMY, false, &HandleDebugDummyCommand, "" }, { "asan", rbac::RBAC_PERM_COMMAND_DEBUG_ASAN, true, nullptr, "", debugAsanCommandTable }, { "guidlimits", rbac::RBAC_PERM_COMMAND_DEBUG, true, &HandleDebugGuidLimitsCommand, "" }, + { "objectcount", rbac::RBAC_PERM_COMMAND_DEBUG, true, &HandleDebugObjectCountCommand, "" }, { "questreset", rbac::RBAC_PERM_COMMAND_DEBUG_QUESTRESET, true, &HandleDebugQuestResetCommand, "" } }; static std::vector commandTable = @@ -1944,6 +1945,39 @@ public: map->GetId(), map->GetMapName(), map->GetInstanceId(), uint64(map->GetMaxLowGuid()), uint64(map->GetMaxLowGuid())); } + static bool HandleDebugObjectCountCommand(ChatHandler* handler, CommandArgs* args) + { + auto mapId = args->TryConsume(); + if (mapId) + { + sMapMgr->DoForAllMapsWithMapId(mapId.get(), + [handler](Map* map) -> void + { + HandleDebugObjectCountMap(handler, map); + } + ); + } + else + { + sMapMgr->DoForAllMaps( + [handler](Map* map) -> void + { + HandleDebugObjectCountMap(handler, map); + } + ); + } + + return true; + } + + static void HandleDebugObjectCountMap(ChatHandler* handler, Map* map) + { + handler->PSendSysMessage("Map Id: %u Name: '%s' Instance Id: %u Creatures: " UI64FMTD " GameObjects: " UI64FMTD, + map->GetId(), map->GetMapName(), map->GetInstanceId(), + uint64(map->GetObjectsStore().Size()), + uint64(map->GetObjectsStore().Size())); + } + static bool HandleDebugDummyCommand(ChatHandler* handler, CommandArgs* /*args*/) { handler->SendSysMessage("This command does nothing right now. Edit your local core (cs_debug.cpp) to make it do whatever you need for testing.");