From 2617dc1b2f8acfaa7284041c66d2334f634e8be5 Mon Sep 17 00:00:00 2001 From: QAston Date: Sat, 13 Jun 2009 17:28:38 +0200 Subject: *Fix Obliterate disease bonus. --HG-- branch : trunk --- src/game/Unit.cpp | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) (limited to 'src/game/Unit.cpp') diff --git a/src/game/Unit.cpp b/src/game/Unit.cpp index a7fdab050e0..86638f14341 100644 --- a/src/game/Unit.cpp +++ b/src/game/Unit.cpp @@ -4428,7 +4428,7 @@ AuraEffect* Unit::GetAura(AuraType type, uint32 family, uint32 familyFlag1, uint return NULL; } -uint32 Unit::GetDiseasesByCaster(uint64 casterGUID) const +uint32 Unit::GetDiseasesByCaster(uint64 casterGUID, bool remove) { static const AuraType diseaseAuraTypes[] = { @@ -4440,13 +4440,22 @@ uint32 Unit::GetDiseasesByCaster(uint64 casterGUID) const uint32 diseases=0; for(AuraType const* itr = &diseaseAuraTypes[0]; itr && itr[0] != SPELL_AURA_NONE; ++itr) { - Unit::AuraEffectList const& auras = GetAurasByType(*itr); - for(AuraEffectList::const_iterator i = auras.begin();i != auras.end(); ++i) + for(AuraEffectList::iterator i = m_modAuras[*itr].begin();i != m_modAuras[*itr].end(); ) { // Get auras with disease dispel type by caster if ((*i)->GetSpellProto()->Dispel == DISPEL_DISEASE && (*i)->GetCasterGUID()==casterGUID) + { ++diseases; + + if (remove) + { + RemoveAura((*i)->GetId(), (*i)->GetCasterGUID()); + i = m_modAuras[*itr].begin(); + continue; + } + } + ++i; } } return diseases; -- cgit v1.2.3