diff options
author | tobmaps <spambot42@yandex.ru> | 2011-05-15 04:24:49 +0700 |
---|---|---|
committer | tobmaps <spambot42@yandex.ru> | 2011-05-15 04:24:49 +0700 |
commit | df3ee186ecaad91693b2c8d4a7600cbd047088f0 (patch) | |
tree | a857d43fc365bec8ff5ffd8b5394fdb21156d9c8 /src | |
parent | d10ca63240078bd4c239fa5241d67cb2f2c6d54b (diff) |
Core/Spells: Fix bug with double haste rating for channeled spells
Diffstat (limited to 'src')
-rwxr-xr-x | src/server/game/Spells/Auras/SpellAuraEffects.cpp | 7 | ||||
-rwxr-xr-x | src/server/game/Spells/Spell.cpp | 10 |
2 files changed, 11 insertions, 6 deletions
diff --git a/src/server/game/Spells/Auras/SpellAuraEffects.cpp b/src/server/game/Spells/Auras/SpellAuraEffects.cpp index 7899ddefdd9..61ef05e3c1f 100755 --- a/src/server/game/Spells/Auras/SpellAuraEffects.cpp +++ b/src/server/game/Spells/Auras/SpellAuraEffects.cpp @@ -830,9 +830,12 @@ void AuraEffect::CalculatePeriodic(Unit * caster, bool create) { // Haste modifies periodic time of channeled spells if (IsChanneledSpell(m_spellProto)) - caster->ModSpellCastTime(m_spellProto, m_amplitude); + { + if (m_spellProto->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) + caster->ModSpellCastTime(m_spellProto, m_amplitude); + } // and periodic time of auras affected by SPELL_AURA_PERIODIC_HASTE - if (caster->HasAuraTypeWithAffectMask(SPELL_AURA_PERIODIC_HASTE, m_spellProto) || m_spellProto->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) + else if (caster->HasAuraTypeWithAffectMask(SPELL_AURA_PERIODIC_HASTE, m_spellProto) || m_spellProto->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) m_amplitude = int32(m_amplitude * caster->GetFloatValue(UNIT_MOD_CAST_SPEED)); } } diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp index 28a8fd03611..37f7d8f708e 100755 --- a/src/server/game/Spells/Spell.cpp +++ b/src/server/game/Spells/Spell.cpp @@ -1505,11 +1505,13 @@ SpellMissInfo Spell::DoSpellHitOnUnit(Unit *unit, const uint32 effectMask, bool duration = m_originalCaster->ModSpellDuration(aurSpellInfo, unit, duration, positive); // Haste modifies duration of channeled spells - if (IsChanneledSpell(m_spellInfo) && m_spellInfo->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) - m_originalCaster->ModSpellCastTime(aurSpellInfo, duration, this); - + if (IsChanneledSpell(m_spellInfo)) + { + if (m_spellInfo->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) + m_originalCaster->ModSpellCastTime(aurSpellInfo, duration, this); + } // and duration of auras affected by SPELL_AURA_PERIODIC_HASTE - if (m_originalCaster->HasAuraTypeWithAffectMask(SPELL_AURA_PERIODIC_HASTE, aurSpellInfo) || m_spellInfo->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) + else if (m_originalCaster->HasAuraTypeWithAffectMask(SPELL_AURA_PERIODIC_HASTE, aurSpellInfo) || (m_spellInfo->AttributesEx5 & SPELL_ATTR5_HASTE_AFFECT_DURATION) duration = int32(duration * m_originalCaster->GetFloatValue(UNIT_MOD_CAST_SPEED)); if (duration != m_spellAura->GetMaxDuration()) |