diff options
| author | Spp <none@none> | 2009-10-18 13:17:05 +0200 |
|---|---|---|
| committer | Spp <none@none> | 2009-10-18 13:17:05 +0200 |
| commit | 8bba043164978bf2a7537d8c466bf9da24dbf726 (patch) | |
| tree | f29ac1e040eadccc587808a60a53671f3eec3d95 /src/game/Wintergrasp.cpp | |
| parent | 3245addf0e04170b4b7ef1a1ff3befcc7783255d (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.cpp | 40 |
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); } |
