From fb66575d38d2ba7ffc24c29824fa75d7019de549 Mon Sep 17 00:00:00 2001 From: Shauren Date: Sat, 1 May 2021 20:16:10 +0200 Subject: Core/Grids: Move packet sending functionality out of MessageDistDeliverer and into separate, customizable class and unify LocalizedPacketDo, LocalizedPacketListDo as generic localizable action --- src/server/game/Texts/ChatTextBuilder.cpp | 36 ++++++++++++++++++++----------- 1 file changed, 24 insertions(+), 12 deletions(-) (limited to 'src/server/game/Texts/ChatTextBuilder.cpp') diff --git a/src/server/game/Texts/ChatTextBuilder.cpp b/src/server/game/Texts/ChatTextBuilder.cpp index 414ebe0ebd2..4abaa62392b 100644 --- a/src/server/game/Texts/ChatTextBuilder.cpp +++ b/src/server/game/Texts/ChatTextBuilder.cpp @@ -16,29 +16,33 @@ */ #include "ChatTextBuilder.h" -#include "ChatPackets.h" +#include "CreatureTextMgr.h" #include "DB2Stores.h" +#include "GridNotifiers.h" #include "ObjectMgr.h" +#include "Player.h" #include -WorldPackets::Packet* Trinity::BroadcastTextBuilder::operator()(LocaleConstant locale) const +namespace Trinity +{ +PacketSenderOwning* BroadcastTextBuilder::operator()(LocaleConstant locale) const { BroadcastTextEntry const* bct = sBroadcastTextStore.LookupEntry(_textId); - WorldPackets::Chat::Chat* chat = new WorldPackets::Chat::Chat(); - chat->Initialize(_msgType, bct ? Language(bct->LanguageID) : LANG_UNIVERSAL, _source, _target, bct ? DB2Manager::GetBroadcastTextValue(bct, locale, _gender) : "", _achievementId, "", locale); + PacketSenderOwning* chat = new PacketSenderOwning(); + chat->Data.Initialize(_msgType, bct ? Language(bct->LanguageID) : LANG_UNIVERSAL, _source, _target, bct ? DB2Manager::GetBroadcastTextValue(bct, locale, _gender) : "", _achievementId, "", locale); return chat; } -WorldPackets::Packet* Trinity::CustomChatTextBuilder::operator()(LocaleConstant locale) const +PacketSenderOwning* CustomChatTextBuilder::operator()(LocaleConstant locale) const { - WorldPackets::Chat::Chat* chat = new WorldPackets::Chat::Chat(); - chat->Initialize(_msgType, _language, _source, _target, _text, 0, "", locale); + PacketSenderOwning* chat = new PacketSenderOwning(); + chat->Data.Initialize(_msgType, _language, _source, _target, _text, 0, "", locale); return chat; } -WorldPackets::Packet* Trinity::TrinityStringChatBuilder::operator()(LocaleConstant locale) const +PacketSenderOwning* TrinityStringChatBuilder::operator()(LocaleConstant locale) const { - WorldPackets::Chat::Chat* packet = new WorldPackets::Chat::Chat(); + PacketSenderOwning* chat = new PacketSenderOwning(); char const* text = sObjectMgr->GetTrinityString(_textId, locale); @@ -53,10 +57,18 @@ WorldPackets::Packet* Trinity::TrinityStringChatBuilder::operator()(LocaleConsta vsnprintf(strBuffer, BufferSize, text, ap); va_end(ap); - packet->Initialize(_msgType, LANG_UNIVERSAL, _source, _target, strBuffer, 0, "", locale); + chat->Data.Initialize(_msgType, LANG_UNIVERSAL, _source, _target, strBuffer, 0, "", locale); } else - packet->Initialize(_msgType, LANG_UNIVERSAL, _source, _target, text, 0, "", locale); + chat->Data.Initialize(_msgType, LANG_UNIVERSAL, _source, _target, text, 0, "", locale); + + return chat; +} - return packet; +PacketSenderOwning* CreatureTextTextBuilder::operator()(LocaleConstant locale) const +{ + PacketSenderOwning* chat = new PacketSenderOwning(); + chat->Data.Initialize(_msgType, _language, _talker, _target, sCreatureTextMgr->GetLocalizedChatString(_source->GetEntry(), _gender, _textGroup, _textId, locale), 0, "", locale); + return chat; +} } -- cgit v1.2.3