aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSnapperRy <snapperryen@gmail.com>2016-09-30 13:16:37 +0200
committerGitHub <noreply@github.com>2016-09-30 13:16:37 +0200
commitf9ea646c82f8cf34f295a5db0be3d7a14c9ca608 (patch)
tree21819a1aed257e5b6ef499dcd075fcf54dac29d8 /src
parent62b166ebb79426ba5cbf2778875b1c286afdddc3 (diff)
Core/World: properly re-initialize daily quest reset time when resetting daily quests. (#17986)
Prevents daily quests from resetting at weird times when restarting the server after a player has completed a daily quest.
Diffstat (limited to 'src')
-rw-r--r--src/server/game/World/World.cpp19
-rw-r--r--src/server/game/World/World.h2
2 files changed, 11 insertions, 10 deletions
diff --git a/src/server/game/World/World.cpp b/src/server/game/World/World.cpp
index de605ee9f2d..e7431bd03a2 100644
--- a/src/server/game/World/World.cpp
+++ b/src/server/game/World/World.cpp
@@ -2103,7 +2103,7 @@ void World::Update(uint32 diff)
if (m_gameTime > m_NextDailyQuestReset)
{
ResetDailyQuests();
- m_NextDailyQuestReset += DAY;
+ InitDailyQuestResetTime(false);
}
/// Handle weekly quests reset time
@@ -2934,18 +2934,19 @@ void World::InitWeeklyQuestResetTime()
m_NextWeeklyQuestReset = wstime < curtime ? curtime : time_t(wstime);
}
-void World::InitDailyQuestResetTime()
+void World::InitDailyQuestResetTime(bool loading)
{
- time_t mostRecentQuestTime;
+ time_t mostRecentQuestTime = 0;
- QueryResult result = CharacterDatabase.Query("SELECT MAX(time) FROM character_queststatus_daily");
- if (result)
+ if (loading)
{
- Field* fields = result->Fetch();
- mostRecentQuestTime = time_t(fields[0].GetUInt32());
+ QueryResult result = CharacterDatabase.Query("SELECT MAX(time) FROM character_queststatus_daily");
+ if (result)
+ {
+ Field* fields = result->Fetch();
+ mostRecentQuestTime = time_t(fields[0].GetUInt32());
+ }
}
- else
- mostRecentQuestTime = 0;
// client built-in time for reset is 6:00 AM
// FIX ME: client not show day start time
diff --git a/src/server/game/World/World.h b/src/server/game/World/World.h
index 4dcb07e2f9c..74a055623f1 100644
--- a/src/server/game/World/World.h
+++ b/src/server/game/World/World.h
@@ -783,7 +783,7 @@ class TC_GAME_API World
// callback for UpdateRealmCharacters
void _UpdateRealmCharCount(PreparedQueryResult resultCharCount);
- void InitDailyQuestResetTime();
+ void InitDailyQuestResetTime(bool loading = true);
void InitWeeklyQuestResetTime();
void InitMonthlyQuestResetTime();
void InitRandomBGResetTime();