aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorVincent-Michael <Vincent_Michael@gmx.de>2015-04-11 05:24:06 +0200
committerVincent-Michael <Vincent_Michael@gmx.de>2015-04-11 05:24:06 +0200
commitcb2bb1c1eeaed549327e862ef9568b06463adee2 (patch)
treed5b3b059dc753ef89f2dc0e8bb8dd8d7ab81bfd4 /src
parentd6311a790bfd2aac811da5cea2bb441e1afafab2 (diff)
Core/Misc: Update page text locale to simple system
Diffstat (limited to 'src')
-rw-r--r--src/server/game/Achievements/AchievementMgr.cpp8
-rw-r--r--src/server/game/Entities/Creature/GossipDef.cpp76
-rw-r--r--src/server/game/Entities/Player/Player.cpp8
-rw-r--r--src/server/game/Globals/ObjectMgr.cpp28
-rw-r--r--src/server/game/Globals/ObjectMgr.h8
-rw-r--r--src/server/game/Handlers/QueryHandler.cpp14
-rw-r--r--src/server/game/Server/Protocol/Opcodes.cpp2
-rw-r--r--src/server/game/Server/WorldSession.h2
8 files changed, 74 insertions, 72 deletions
diff --git a/src/server/game/Achievements/AchievementMgr.cpp b/src/server/game/Achievements/AchievementMgr.cpp
index bb3700c9423..d7c67efa72d 100644
--- a/src/server/game/Achievements/AchievementMgr.cpp
+++ b/src/server/game/Achievements/AchievementMgr.cpp
@@ -1750,13 +1750,13 @@ void AchievementMgr<Player>::CompletedAchievement(AchievementEntry const* achiev
std::string subject = reward->subject;
std::string text = reward->text;
- int locIdx = GetOwner()->GetSession()->GetSessionDbLocaleIndex();
- if (locIdx >= 0)
+ LocaleConstant localeConstant = GetOwner()->GetSession()->GetSessionDbLocaleIndex();
+ if (localeConstant >= LOCALE_enUS)
{
if (AchievementRewardLocale const* loc = sAchievementMgr->GetAchievementRewardLocale(achievement))
{
- ObjectMgr::GetLocaleString(loc->subject, locIdx, subject);
- ObjectMgr::GetLocaleString(loc->text, locIdx, text);
+ ObjectMgr::GetLocaleString(loc->subject, localeConstant, subject);
+ ObjectMgr::GetLocaleString(loc->text, localeConstant, text);
}
}
diff --git a/src/server/game/Entities/Creature/GossipDef.cpp b/src/server/game/Entities/Creature/GossipDef.cpp
index 6c2d1f19a63..f84c962510c 100644
--- a/src/server/game/Entities/Creature/GossipDef.cpp
+++ b/src/server/game/Entities/Creature/GossipDef.cpp
@@ -235,10 +235,10 @@ void PlayerMenu::SendGossipMenu(uint32 titleTextId, ObjectGuid objectGUID)
text.Repeatable = quest->IsRepeatable();
std::string title = quest->GetLogTitle();
- int32 locale = _session->GetSessionDbLocaleIndex();
- if (locale >= 0)
+ LocaleConstant localeConstant = _session->GetSessionDbLocaleIndex();
+ if (localeConstant >= LOCALE_enUS)
if (QuestTemplateLocale const* localeData = sObjectMgr->GetQuestLocale(questID))
- ObjectMgr::GetLocaleString(localeData->LogTitle, locale, title);
+ ObjectMgr::GetLocaleString(localeData->LogTitle, localeConstant, title);
if (questLevelInTitle)
AddQuestLevelToTitle(title, quest->GetQuestLevel());
@@ -272,10 +272,10 @@ void PlayerMenu::SendPointOfInterest(uint32 poiId) const
}
std::string iconText = poi->Name;
- int32 locale = _session->GetSessionDbLocaleIndex();
- if (locale >= 0)
+ LocaleConstant localeConstant = _session->GetSessionDbLocaleIndex();
+ if (localeConstant >= LOCALE_enUS)
if (PointOfInterestLocale const* localeData = sObjectMgr->GetPointOfInterestLocale(poiId))
- ObjectMgr::GetLocaleString(localeData->IconName, locale, iconText);
+ ObjectMgr::GetLocaleString(localeData->IconName, localeConstant, iconText);
WorldPacket data(SMSG_GOSSIP_POI, 4 + 4 + 4 + 4 + 4 + 10); // guess size
data << uint32(poi->Flags);
@@ -358,10 +358,10 @@ void PlayerMenu::SendQuestGiverQuestList(ObjectGuid guid)
{
std::string title = quest->GetLogTitle();
- LocaleConstant locale = _session->GetSessionDbLocaleIndex();
- if (locale >= LOCALE_enUS)
- if (QuestTemplateLocale const* questTemplateLocaleData = sObjectMgr->GetQuestLocale(questID))
- ObjectMgr::GetLocaleString(questTemplateLocaleData->LogTitle, locale, title);
+ LocaleConstant localeConstant = _session->GetSessionDbLocaleIndex();
+ if (localeConstant >= LOCALE_enUS)
+ if (QuestTemplateLocale const* questTemplateLocale = sObjectMgr->GetQuestLocale(questID))
+ ObjectMgr::GetLocaleString(questTemplateLocale->LogTitle, localeConstant, title);
if (questLevelInTitle)
AddQuestLevelToTitle(title, quest->GetQuestLevel());
@@ -391,23 +391,23 @@ void PlayerMenu::SendQuestGiverQuestDetails(Quest const* quest, ObjectGuid npcGU
std::string questLogTitle = quest->GetLogTitle();
std::string questLogDescription = quest->GetLogDescription();
std::string questDescription = quest->GetQuestDescription();
- std::string portraitGiverText = quest->GetPortraitGiverText();
- std::string portraitGiverName = quest->GetPortraitGiverName();
- std::string portraitTurnInText = quest->GetPortraitTurnInText();
- std::string portraitTurnInName = quest->GetPortraitTurnInName();
+ std::string portraitGiverText = quest->GetPortraitGiverText();
+ std::string portraitGiverName = quest->GetPortraitGiverName();
+ std::string portraitTurnInText = quest->GetPortraitTurnInText();
+ std::string portraitTurnInName = quest->GetPortraitTurnInName();
- int32 locale = _session->GetSessionDbLocaleIndex();
- if (locale >= 0)
+ LocaleConstant localeConstant = _session->GetSessionDbLocaleIndex();
+ if (localeConstant >= LOCALE_enUS)
{
- if (QuestTemplateLocale const* localeData = sObjectMgr->GetQuestLocale(quest->GetQuestId()))
+ if (QuestTemplateLocale const* questTemplateLocale = sObjectMgr->GetQuestLocale(quest->GetQuestId()))
{
- ObjectMgr::GetLocaleString(localeData->LogTitle, locale, questLogTitle);
- ObjectMgr::GetLocaleString(localeData->LogDescription, locale, questLogDescription);
- ObjectMgr::GetLocaleString(localeData->QuestDescription, locale, questDescription);
- ObjectMgr::GetLocaleString(localeData->PortraitGiverText, locale, portraitGiverText);
- ObjectMgr::GetLocaleString(localeData->PortraitGiverName, locale, portraitGiverName);
- ObjectMgr::GetLocaleString(localeData->PortraitTurnInText, locale, portraitTurnInText);
- ObjectMgr::GetLocaleString(localeData->PortraitTurnInName, locale, portraitTurnInName);
+ ObjectMgr::GetLocaleString(questTemplateLocale->LogTitle, localeConstant, questLogTitle);
+ ObjectMgr::GetLocaleString(questTemplateLocale->LogDescription, localeConstant, questLogDescription);
+ ObjectMgr::GetLocaleString(questTemplateLocale->QuestDescription, localeConstant, questDescription);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitGiverText, localeConstant, portraitGiverText);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitGiverName, localeConstant, portraitGiverName);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitTurnInText, localeConstant, portraitTurnInText);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitTurnInName, localeConstant, portraitTurnInName);
}
}
@@ -461,7 +461,7 @@ void PlayerMenu::SendQuestGiverQuestDetails(Quest const* quest, ObjectGuid npcGU
void PlayerMenu::SendQuestQueryResponse(Quest const* quest) const
{
- LocaleConstant locale = _session->GetSessionDbLocaleIndex();
+ LocaleConstant LocaleConstant = _session->GetSessionDbLocaleIndex();
std::string questLogTitle = quest->GetLogTitle();
std::string questLogDescription = quest->GetLogDescription();
@@ -473,19 +473,19 @@ void PlayerMenu::SendQuestQueryResponse(Quest const* quest) const
std::string portraitTurnInText = quest->GetPortraitTurnInText();
std::string portraitTurnInName = quest->GetPortraitTurnInName();
- if (locale >= LOCALE_enUS)
+ if (LocaleConstant >= LOCALE_enUS)
{
if (QuestTemplateLocale const* questTemplateLocale = sObjectMgr->GetQuestLocale(quest->GetQuestId()))
{
- ObjectMgr::GetLocaleString(questTemplateLocale->LogTitle, locale, questLogTitle);
- ObjectMgr::GetLocaleString(questTemplateLocale->LogDescription, locale, questLogDescription);
- ObjectMgr::GetLocaleString(questTemplateLocale->QuestDescription, locale, questDescription);
- ObjectMgr::GetLocaleString(questTemplateLocale->AreaDescription, locale, areaDescription);
- ObjectMgr::GetLocaleString(questTemplateLocale->QuestCompletionLog, locale, questCompletionLog);
- ObjectMgr::GetLocaleString(questTemplateLocale->PortraitGiverText, locale, portraitGiverText);
- ObjectMgr::GetLocaleString(questTemplateLocale->PortraitGiverName, locale, portraitGiverName);
- ObjectMgr::GetLocaleString(questTemplateLocale->PortraitTurnInText, locale, portraitTurnInText);
- ObjectMgr::GetLocaleString(questTemplateLocale->PortraitTurnInName, locale, portraitTurnInName);
+ ObjectMgr::GetLocaleString(questTemplateLocale->LogTitle, LocaleConstant, questLogTitle);
+ ObjectMgr::GetLocaleString(questTemplateLocale->LogDescription, LocaleConstant, questLogDescription);
+ ObjectMgr::GetLocaleString(questTemplateLocale->QuestDescription, LocaleConstant, questDescription);
+ ObjectMgr::GetLocaleString(questTemplateLocale->AreaDescription, LocaleConstant, areaDescription);
+ ObjectMgr::GetLocaleString(questTemplateLocale->QuestCompletionLog, LocaleConstant, questCompletionLog);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitGiverText, LocaleConstant, portraitGiverText);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitGiverName, LocaleConstant, portraitGiverName);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitTurnInText, LocaleConstant, portraitTurnInText);
+ ObjectMgr::GetLocaleString(questTemplateLocale->PortraitTurnInName, LocaleConstant, portraitTurnInName);
}
}
@@ -576,10 +576,10 @@ void PlayerMenu::SendQuestQueryResponse(Quest const* quest) const
{
packet.Info.Objectives.push_back(questObjective);
- if (locale >= LOCALE_enUS)
+ if (LocaleConstant >= LOCALE_enUS)
{
- if (QuestObjectivesLocale const* questObjectivesLocaleData = sObjectMgr->GetQuestObjectivesLocale(questObjective.ID))
- ObjectMgr::GetLocaleString(questObjectivesLocaleData->Description, locale, packet.Info.Objectives.back().Description);
+ if (QuestObjectivesLocale const* questObjectivesLocale = sObjectMgr->GetQuestObjectivesLocale(questObjective.ID))
+ ObjectMgr::GetLocaleString(questObjectivesLocale->Description, LocaleConstant, packet.Info.Objectives.back().Description);
}
}
diff --git a/src/server/game/Entities/Player/Player.cpp b/src/server/game/Entities/Player/Player.cpp
index fd2dc78a06b..6fe8f34a5af 100644
--- a/src/server/game/Entities/Player/Player.cpp
+++ b/src/server/game/Entities/Player/Player.cpp
@@ -16263,10 +16263,10 @@ void Player::SendQuestConfirmAccept(const Quest* quest, Player* pReceiver)
{
std::string strTitle = quest->GetLogTitle();
- int loc_idx = pReceiver->GetSession()->GetSessionDbLocaleIndex();
- if (loc_idx >= 0)
- if (const QuestTemplateLocale* pLocale = sObjectMgr->GetQuestLocale(quest->GetQuestId()))
- ObjectMgr::GetLocaleString(pLocale->LogTitle, loc_idx, strTitle);
+ LocaleConstant localeConstant = pReceiver->GetSession()->GetSessionDbLocaleIndex();
+ if (localeConstant >= 0)
+ if (QuestTemplateLocale const* questTemplateLocale = sObjectMgr->GetQuestLocale(quest->GetQuestId()))
+ ObjectMgr::GetLocaleString(questTemplateLocale->LogTitle, localeConstant, strTitle);
WorldPacket data(SMSG_QUEST_CONFIRM_ACCEPT, (4 + strTitle.size() + 8));
data << uint32(quest->GetQuestId());
diff --git a/src/server/game/Globals/ObjectMgr.cpp b/src/server/game/Globals/ObjectMgr.cpp
index c9c684e1f29..2aee9fb9193 100644
--- a/src/server/game/Globals/ObjectMgr.cpp
+++ b/src/server/game/Globals/ObjectMgr.cpp
@@ -302,14 +302,14 @@ ObjectMgr::~ObjectMgr()
delete itr->second;
}
-void ObjectMgr::AddLocaleString(std::string const& s, LocaleConstant locale, StringVector& data)
+void ObjectMgr::AddLocaleString(std::string const& value, LocaleConstant localeConstant, StringVector& data)
{
- if (!s.empty())
+ if (!value.empty())
{
- if (data.size() <= size_t(locale))
- data.resize(locale + 1);
+ if (data.size() <= size_t(localeConstant))
+ data.resize(localeConstant + 1);
- data[locale] = s;
+ data[localeConstant] = value;
}
}
@@ -4839,7 +4839,6 @@ void ObjectMgr::LoadPageTexts()
// 0 1 2
QueryResult result = WorldDatabase.Query("SELECT ID, Text, NextPageID FROM page_text");
-
if (!result)
{
TC_LOG_INFO("server.loading", ">> Loaded 0 page texts. DB table `page_text` is empty!");
@@ -4851,8 +4850,9 @@ void ObjectMgr::LoadPageTexts()
{
Field* fields = result->Fetch();
- PageText& pageText = _pageTextStore[fields[0].GetUInt32()];
+ uint32 id = fields[0].GetUInt32();
+ PageText& pageText = _pageTextStore[id];
pageText.Text = fields[1].GetString();
pageText.NextPageID = fields[2].GetUInt32();
@@ -4889,8 +4889,8 @@ void ObjectMgr::LoadPageTextLocales()
_pageTextLocaleStore.clear(); // needed for reload case
- QueryResult result = WorldDatabase.Query("SELECT ID, Text_loc1, Text_loc2, Text_loc3, Text_loc4, Text_loc5, Text_loc6, Text_loc7, Text_loc8 FROM locales_page_text");
-
+ // 0 1 2
+ QueryResult result = WorldDatabase.Query("SELECT ID, locale, Text FROM page_text_locale");
if (!result)
return;
@@ -4898,12 +4898,14 @@ void ObjectMgr::LoadPageTextLocales()
{
Field* fields = result->Fetch();
- uint32 entry = fields[0].GetUInt32();
+ uint32 id = fields[0].GetUInt32();
+ std::string localeName = fields[1].GetString();
+ std::string text = fields[2].GetString();
- PageTextLocale& data = _pageTextLocaleStore[entry];
+ PageTextLocale& data = _pageTextLocaleStore[id];
+ LocaleConstant locale = GetLocaleByName(localeName);
- for (uint8 i = OLD_TOTAL_LOCALES - 1; i > 0; --i)
- AddLocaleString(fields[i].GetString(), LocaleConstant(i), data.Text);
+ AddLocaleString(text, locale, data.Text);
} while (result->NextRow());
TC_LOG_INFO("server.loading", ">> Loaded %u PageText locale strings in %u ms", uint32(_pageTextLocaleStore.size()), GetMSTimeDiffToNow(oldMSTime));
diff --git a/src/server/game/Globals/ObjectMgr.h b/src/server/game/Globals/ObjectMgr.h
index 4be71b68757..240b80b4a44 100644
--- a/src/server/game/Globals/ObjectMgr.h
+++ b/src/server/game/Globals/ObjectMgr.h
@@ -1274,11 +1274,11 @@ class ObjectMgr
// for wintergrasp only
GraveYardContainer GraveYardStore;
- static void AddLocaleString(std::string const& s, LocaleConstant locale, StringVector& data);
- static inline void GetLocaleString(const StringVector& data, int loc_idx, std::string& value)
+ static void AddLocaleString(std::string const& value, LocaleConstant localeConstant, StringVector& data);
+ static inline void GetLocaleString(StringVector const& data, LocaleConstant localeConstant, std::string& value)
{
- if (data.size() > size_t(loc_idx) && !data[loc_idx].empty())
- value = data[loc_idx];
+ if (data.size() > size_t(localeConstant) && !data[localeConstant].empty())
+ value = data[localeConstant];
}
CharacterConversionMap FactionChangeAchievements;
diff --git a/src/server/game/Handlers/QueryHandler.cpp b/src/server/game/Handlers/QueryHandler.cpp
index 80b9daa33fb..7dad6bec4e7 100644
--- a/src/server/game/Handlers/QueryHandler.cpp
+++ b/src/server/game/Handlers/QueryHandler.cpp
@@ -228,9 +228,9 @@ void WorldSession::HandleNpcTextQueryOpcode(WorldPackets::Query::QueryNPCText& p
}
/// Only _static_ data is sent in this packet !!!
-void WorldSession::HandlePageTextQueryOpcode(WorldPackets::Query::QueryPageText& packet)
+void WorldSession::HandleQueryPageText(WorldPackets::Query::QueryPageText& packet)
{
- TC_LOG_DEBUG("network", "WORLD: Received CMSG_PAGE_TEXT_QUERY");
+ TC_LOG_DEBUG("network", "WORLD: Received CMSG_QUERY_PAGE_TEXT");
uint32 pageID = packet.PageTextID;
@@ -251,10 +251,10 @@ void WorldSession::HandlePageTextQueryOpcode(WorldPackets::Query::QueryPageText&
response.Allow = true;
response.Info.ID = pageID;
- int loc_idx = GetSessionDbLocaleIndex();
- if (loc_idx >= 0)
- if (PageTextLocale const* player = sObjectMgr->GetPageTextLocale(pageID))
- ObjectMgr::GetLocaleString(player->Text, loc_idx, response.Info.Text);
+ LocaleConstant localeConstant = GetSessionDbLocaleIndex();
+ if (localeConstant >= LOCALE_enUS)
+ if (PageTextLocale const* pageTextLocale = sObjectMgr->GetPageTextLocale(pageID))
+ ObjectMgr::GetLocaleString(pageTextLocale->Text, localeConstant, response.Info.Text);
response.Info.NextPageID = pageText->NextPageID;
pageID = pageText->NextPageID;
@@ -262,7 +262,7 @@ void WorldSession::HandlePageTextQueryOpcode(WorldPackets::Query::QueryPageText&
SendPacket(response.Write());
- TC_LOG_DEBUG("network", "WORLD: Sent SMSG_PAGE_TEXT_QUERY_RESPONSE");
+ TC_LOG_DEBUG("network", "WORLD: Sent SMSG_QUERY_PAGE_TEXT_RESPONSE");
}
}
diff --git a/src/server/game/Server/Protocol/Opcodes.cpp b/src/server/game/Server/Protocol/Opcodes.cpp
index fd1dbcb8cee..ad81c72acd0 100644
--- a/src/server/game/Server/Protocol/Opcodes.cpp
+++ b/src/server/game/Server/Protocol/Opcodes.cpp
@@ -628,7 +628,7 @@ void OpcodeTable::Initialize()
DEFINE_HANDLER(CMSG_QUERY_INSPECT_ACHIEVEMENTS, STATUS_UNHANDLED, PROCESS_THREADUNSAFE, WorldPackets::Inspect::QueryInspectAchievements, &WorldSession::HandleQueryInspectAchievements);
DEFINE_HANDLER(CMSG_QUERY_NEXT_MAIL_TIME, STATUS_LOGGEDIN, PROCESS_THREADUNSAFE, WorldPackets::Mail::MailQueryNextMailTime, &WorldSession::HandleQueryNextMailTime);
DEFINE_HANDLER(CMSG_QUERY_NPC_TEXT, STATUS_LOGGEDIN, PROCESS_THREADUNSAFE, WorldPackets::Query::QueryNPCText, &WorldSession::HandleNpcTextQueryOpcode);
- DEFINE_HANDLER(CMSG_QUERY_PAGE_TEXT, STATUS_LOGGEDIN, PROCESS_THREADUNSAFE, WorldPackets::Query::QueryPageText, &WorldSession::HandlePageTextQueryOpcode);
+ DEFINE_HANDLER(CMSG_QUERY_PAGE_TEXT, STATUS_LOGGEDIN, PROCESS_THREADUNSAFE, WorldPackets::Query::QueryPageText, &WorldSession::HandleQueryPageText);
DEFINE_HANDLER(CMSG_QUERY_PETITION, STATUS_UNHANDLED, PROCESS_THREADUNSAFE, WorldPackets::Petition::QueryPetition, &WorldSession::HandleQueryPetition);
DEFINE_OPCODE_HANDLER_OLD(CMSG_QUERY_PET_NAME, STATUS_UNHANDLED, PROCESS_THREADUNSAFE, &WorldSession::HandlePetNameQuery );
DEFINE_HANDLER(CMSG_QUERY_PLAYER_NAME, STATUS_LOGGEDIN, PROCESS_THREADUNSAFE, WorldPackets::Query::QueryPlayerName, &WorldSession::HandleNameQueryOpcode);
diff --git a/src/server/game/Server/WorldSession.h b/src/server/game/Server/WorldSession.h
index df01abfc0c7..c087bbcd462 100644
--- a/src/server/game/Server/WorldSession.h
+++ b/src/server/game/Server/WorldSession.h
@@ -1240,7 +1240,7 @@ class WorldSession
void HandleCompleteCinematic(WorldPacket& recvPacket);
void HandleNextCinematicCamera(WorldPacket& recvPacket);
- void HandlePageTextQueryOpcode(WorldPackets::Query::QueryPageText& packet);
+ void HandleQueryPageText(WorldPackets::Query::QueryPageText& packet);
void HandleTutorialFlag(WorldPackets::Misc::TutorialSetFlag& packet);