diff options
| author | SnapperRy <snapperryen@gmail.com> | 2016-09-30 13:16:37 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-09-30 13:16:37 +0200 |
| commit | f9ea646c82f8cf34f295a5db0be3d7a14c9ca608 (patch) | |
| tree | 21819a1aed257e5b6ef499dcd075fcf54dac29d8 /src | |
| parent | 62b166ebb79426ba5cbf2778875b1c286afdddc3 (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.cpp | 19 | ||||
| -rw-r--r-- | src/server/game/World/World.h | 2 |
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(); |
