diff options
author | spp <none@none> | 2009-12-06 18:21:00 +0100 |
---|---|---|
committer | spp <none@none> | 2009-12-06 18:21:00 +0100 |
commit | 9e2c09bf09aea00593012abbf84e3bd6f8f6bab9 (patch) | |
tree | 8ee174046201ac13249223f52c1040f5720c03cb /src/game/Level2.cpp | |
parent | 2acf288071a08682459518f52e0aacdf6131c17d (diff) |
Wintergrasp .wg command fixes. Closes #442
* .wg timer: limit to 1-60 wartime and 1-2440 not wartime
* .wg switch: timer will not be reset.
--HG--
branch : trunk
Diffstat (limited to 'src/game/Level2.cpp')
-rw-r--r-- | src/game/Level2.cpp | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/src/game/Level2.cpp b/src/game/Level2.cpp index 5965a9f283b..836acbb3174 100644 --- a/src/game/Level2.cpp +++ b/src/game/Level2.cpp @@ -4346,13 +4346,21 @@ bool ChatHandler::HandleWintergraspTimerCommand(const char* args) int32 time = atoi (args); - if (time <= 0 || time > 60) - return false; + // Min value 1 min + if (1 > time) + time = 1; + // Max value during wartime = 60. No wartime = 1440 (day) + if (pvpWG->isWarTime()) + { + if (60 < time) + return false; + } else - time *= MINUTE * IN_MILISECONDS; + if (1440 < time) + return false; + time *= MINUTE * IN_MILISECONDS; pvpWG->setTimer((uint32)time); - PSendSysMessage(LANG_BG_WG_CHANGE_TIMER, secsToTimeString(pvpWG->GetTimer(), true).c_str()); return true; } @@ -4367,7 +4375,9 @@ bool ChatHandler::HandleWintergraspSwitchTeamCommand(const char* args) SetSentErrorMessage(true); return false; } + uint32 timer = pvpWG->GetTimer(); pvpWG->forceChangeTeam(); + pvpWG->setTimer(timer); PSendSysMessage(LANG_BG_WG_SWITCH_FACTION, GetTrinityString(pvpWG->GetTeam() == TEAM_ALLIANCE ? LANG_BG_AB_ALLY : LANG_BG_AB_HORDE)); return true; } |