aboutsummaryrefslogtreecommitdiff
path: root/src/game/Wintergrasp.cpp
diff options
context:
space:
mode:
authorSpp <none@none>2009-10-18 13:17:05 +0200
committerSpp <none@none>2009-10-18 13:17:05 +0200
commit8bba043164978bf2a7537d8c466bf9da24dbf726 (patch)
treef29ac1e040eadccc587808a60a53671f3eec3d95 /src/game/Wintergrasp.cpp
parent3245addf0e04170b4b7ef1a1ff3befcc7783255d (diff)
*Wintergrasp: Tenacity applied when player resurrects. By Spp
*OutdoorPvP: Implementation of HandlePlayerResurrects. By Spp *Wintergrasp: Fix to honor rewards (DestroyedTower never applied). By Spp *Wintergrasp: Fix to Spirit Healers (werent visible during wartime). By Spp --HG-- branch : trunk
Diffstat (limited to 'src/game/Wintergrasp.cpp')
-rw-r--r--src/game/Wintergrasp.cpp40
1 files changed, 35 insertions, 5 deletions
diff --git a/src/game/Wintergrasp.cpp b/src/game/Wintergrasp.cpp
index 4e7e507787b..d98f8d11511 100644
--- a/src/game/Wintergrasp.cpp
+++ b/src/game/Wintergrasp.cpp
@@ -33,14 +33,15 @@ enum WintergraspQuest
NO_MERCY_MERCILESS_1 = 13179, //Alliance Quest
A_VICTORY_IN_WG = 13181,
- H_VICTORY_IN_WG = 13183
+ H_VICTORY_IN_WG = 13183,
};
enum CreatureEntry
{
CRE_ENG_A = 30499,
CRE_ENG_H = 30400,
- CRE_PVP_KILL = 31086 //Quest Objective
+ CRE_PVP_KILL = 31086, //Quest Objective
+ SPIRIT_HEALER = 6491,
};
const TeamPair CreatureEntryPair[] =
@@ -86,6 +87,11 @@ void LoadTeamPair(TeamPairMap &pairMap, const TeamPair *pair)
typedef std::list<const AreaPOIEntry *> AreaPOIList;
+OPvPWintergrasp::OPvPWintergrasp()
+{
+ m_TypeId = OPVP_WINTERGRASP;
+}
+
bool OPvPWintergrasp::SetupOutdoorPvP()
{
if(!sWorld.getConfig(CONFIG_OUTDOORPVP_WINTERGRASP_ENABLED))
@@ -95,6 +101,8 @@ bool OPvPWintergrasp::SetupOutdoorPvP()
m_changeDefender = false;
m_workshopCount[TEAM_ALLIANCE] = 0;
m_workshopCount[TEAM_HORDE] = 0;
+ m_tenacityStack = 0;
+ m_gate = NULL;
// Select POI
AreaPOIList areaPOIs;
@@ -433,6 +441,7 @@ WintergraspCreType OPvPWintergrasp::GetCreatureType(uint32 entry) const
case 32296:case 32294: // Quartermaster
case 30870:case 30869: // Flight Masters
case 31841:case 31842: // Spirit Guides
+ case SPIRIT_HEALER: // Spirit Healers
return CREATURE_SPECIAL;
default:
return CREATURE_OTHER; // Revenants, Elementals, etc
@@ -753,6 +762,19 @@ void OPvPWintergrasp::HandlePlayerEnterZone(Player * plr, uint32 zone)
UpdateTenacityStack();
}
+// Reapply Tenacity if needed
+void OPvPWintergrasp::HandlePlayerResurrects(Player * plr, uint32 zone)
+{
+ if (isWarTime() && m_tenacityStack && !plr->HasAura(SPELL_TENACITY) && plr->getLevel() > 69)
+ {
+ int32 newStack = m_tenacityStack < 0 ? -m_tenacityStack : m_tenacityStack;
+ if (newStack > 20)
+ newStack = 20;
+ CastTenacity(plr, newStack);
+ }
+ OutdoorPvP::HandlePlayerResurrects(plr, zone);
+}
+
void OPvPWintergrasp::HandlePlayerLeaveZone(Player * plr, uint32 zone)
{
if (!plr->GetSession()->PlayerLogout())
@@ -852,10 +874,18 @@ void OPvPWintergrasp::UpdateTenacityStack()
return;
TeamId team = TEAM_NEUTRAL;
- uint32 allianceNum = m_players[TEAM_ALLIANCE].size();;
- uint32 hordeNum = m_players[TEAM_HORDE].size();;
+ uint32 allianceNum = 0;
+ uint32 hordeNum = 0;
int32 newStack = 0;
+ for (PlayerSet::iterator itr = m_players[TEAM_ALLIANCE].begin(); itr != m_players[TEAM_ALLIANCE].end(); ++itr)
+ if ((*itr)->getLevel() > 69)
+ ++allianceNum;
+
+ for (PlayerSet::iterator itr = m_players[TEAM_HORDE].begin(); itr != m_players[TEAM_HORDE].end(); ++itr)
+ if ((*itr)->getLevel() > 69)
+ ++hordeNum;
+
if (allianceNum && hordeNum)
{
if (allianceNum < hordeNum)
@@ -1049,7 +1079,7 @@ void OPvPWintergrasp::EndBattle()
baseHonor = m_customHonorReward[(team == getDefenderTeam()) ? WIN_BATTLE : LOSE_BATTLE];
baseHonor += (m_customHonorReward[DAMAGED_TOWER] * m_towerCount[OTHER_TEAM(team)][DAMAGED_TOWER]);
- baseHonor += (m_customHonorReward[DESTROYED_TOWER] * m_towerCount[OTHER_TEAM(team)][DAMAGED_TOWER]);
+ baseHonor += (m_customHonorReward[DESTROYED_TOWER] * m_towerCount[OTHER_TEAM(team)][DESTROYED_TOWER]);
baseHonor += (m_customHonorReward[INTACT_BUILDING] * intactNum);
baseHonor += (m_customHonorReward[DAMAGED_BUILDING] * damagedNum);
}