diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/server/game/Spells/SpellEffects.cpp | 66 | ||||
| -rw-r--r-- | src/server/game/Spells/SpellMgr.cpp | 6 | 
2 files changed, 7 insertions, 65 deletions
| diff --git a/src/server/game/Spells/SpellEffects.cpp b/src/server/game/Spells/SpellEffects.cpp index 53bb34eae34..6c3afc4afe7 100644 --- a/src/server/game/Spells/SpellEffects.cpp +++ b/src/server/game/Spells/SpellEffects.cpp @@ -1165,14 +1165,6 @@ void Spell::EffectPowerBurn(SpellEffIndex effIndex)      if (!unitTarget || !unitTarget->IsAlive() || unitTarget->getPowerType() != powerType || damage < 0)          return; -    // burn x% of target's mana, up to maximum of 2x% of caster's mana (Mana Burn) -    if (m_spellInfo->Id == 8129) -    { -        int32 maxDamage = int32(CalculatePct(m_caster->GetMaxPower(powerType), damage * 2)); -        damage = int32(CalculatePct(unitTarget->GetMaxPower(powerType), damage)); -        damage = std::min(damage, maxDamage); -    } -      int32 newDamage = -(unitTarget->ModifyPower(powerType, -damage));      // NO - Not a typo - EffectPowerBurn uses effect value multiplier - not effect damage multiplier @@ -1222,51 +1214,6 @@ void Spell::EffectHeal(SpellEffIndex /*effIndex*/)                  if (player->HasSkill(SKILL_ENGINEERING))                      AddPct(addhealth, 25);          } -        // Swiftmend - consumes Regrowth or Rejuvenation -        else if (m_spellInfo->TargetAuraState == AURA_STATE_SWIFTMEND && unitTarget->HasAuraState(AURA_STATE_SWIFTMEND, m_spellInfo, m_caster)) -        { -            Unit::AuraEffectList const& RejorRegr = unitTarget->GetAuraEffectsByType(SPELL_AURA_PERIODIC_HEAL); -            // find most short by duration -            AuraEffect* targetAura = NULL; -            for (Unit::AuraEffectList::const_iterator i = RejorRegr.begin(); i != RejorRegr.end(); ++i) -            { -                if ((*i)->GetSpellInfo()->SpellFamilyName == SPELLFAMILY_DRUID -                    && (*i)->GetSpellInfo()->SpellFamilyFlags[0] & 0x50) -                { -                    if (!targetAura || (*i)->GetBase()->GetDuration() < targetAura->GetBase()->GetDuration()) -                        targetAura = *i; -                } -            } - -            if (!targetAura) -            { -                TC_LOG_ERROR("spells", "Target (%s) has the aurastate AURA_STATE_SWIFTMEND, but no matching aura.", unitTarget->GetGUID().ToString().c_str()); -                return; -            } - -            int32 tickheal = targetAura->GetAmount(); -            if (Unit* auraCaster = targetAura->GetCaster()) -                tickheal = auraCaster->SpellHealingBonusDone(unitTarget, targetAura->GetSpellInfo(), tickheal, DOT, effectInfo); -            //int32 tickheal = targetAura->GetSpellInfo()->EffectBasePoints[idx] + 1; -            //It is said that talent bonus should not be included - -            int32 tickcount = 0; -            // Rejuvenation -            if (targetAura->GetSpellInfo()->SpellFamilyFlags[0] & 0x10) -                tickcount = 4; -            // Regrowth -            else // if (targetAura->GetSpellInfo()->SpellFamilyFlags[0] & 0x40) -                tickcount = 6; - -            addhealth += tickheal * tickcount; - -            // Glyph of Swiftmend -            if (!caster->HasAura(54824)) -                unitTarget->RemoveAura(targetAura->GetId(), targetAura->GetCasterGUID()); - -            //addhealth += tickheal * tickcount; -            //addhealth = caster->SpellHealingBonus(m_spellInfo, addhealth, HEAL, unitTarget); -        }          // Death Pact - return pct of max health to caster          else if (m_spellInfo->SpellFamilyName == SPELLFAMILY_DEATHKNIGHT && m_spellInfo->SpellFamilyFlags[0] & 0x00080000)              addhealth = caster->SpellHealingBonusDone(unitTarget, m_spellInfo, int32(caster->CountPctFromMaxHealth(damage)), HEAL, effectInfo); @@ -2098,10 +2045,6 @@ void Spell::EffectSummonType(SpellEffIndex effIndex)                      if (!summon || !summon->IsTotem())                          return; -                    // Mana Tide Totem -                    if (m_spellInfo->Id == 16190) -                        damage = m_caster->CountPctFromMaxHealth(10); -                      if (damage)                                            // if not spell info, DB values used                      {                          summon->SetMaxHealth(damage); @@ -5074,14 +5017,7 @@ void Spell::EffectKillCredit(SpellEffIndex /*effIndex*/)      if (!unitTarget || unitTarget->GetTypeId() != TYPEID_PLAYER)          return; -    int32 creatureEntry = effectInfo->MiscValue; -    if (!creatureEntry) -    { -        if (m_spellInfo->Id == 42793) // Burn Body -            creatureEntry = 24008; // Fallen Combatant -    } - -    if (creatureEntry) +    if (int32 creatureEntry = effectInfo->MiscValue)          unitTarget->ToPlayer()->RewardPlayerAndGroupAtEvent(creatureEntry, unitTarget);  } diff --git a/src/server/game/Spells/SpellMgr.cpp b/src/server/game/Spells/SpellMgr.cpp index 0d949f26d75..41ab8d803b6 100644 --- a/src/server/game/Spells/SpellMgr.cpp +++ b/src/server/game/Spells/SpellMgr.cpp @@ -3187,6 +3187,12 @@ void SpellMgr::LoadSpellInfoCorrections()          const_cast<SpellEffectInfo*>(spellInfo->GetEffect(EFFECT_0))->TargetA = SpellImplicitTargetInfo(TARGET_UNIT_NEARBY_ENTRY);      }); +    // Burn Body +    ApplySpellFix({ 42793 }, [](SpellInfo* spellInfo) +    { +        const_cast<SpellEffectInfo*>(spellInfo->GetEffect(EFFECT_2))->MiscValue = 24008; // Fallen Combatant +    }); +      //      // VIOLET HOLD SPELLS      // | 
