diff --git a/src/game/Spells/Spell.cpp b/src/game/Spells/Spell.cpp index 4e2030494c3..f127ac1002e 100644 --- a/src/game/Spells/Spell.cpp +++ b/src/game/Spells/Spell.cpp @@ -3806,17 +3806,23 @@ SpellCastResult Spell::cast(bool skipCheck) } } + uint32 procAttacker; + uint32 procVictim; + uint32 procEx = PROC_EX_NONE; + PrepareMasksForProcSystem(EFFECT_MASK_ALL, procAttacker, procVictim, m_trueCaster, nullptr); // on spell cast end proc, // critical hit related part is currently done on hit so proc there, // 0 damage since any damage based procs should be on hit // 0 victim proc since there is no victim proc dependent on successfull cast for caster - Unit::ProcDamageAndSpell(ProcSystemArguments(m_caster, procTarget, PROC_EX_NORMAL_HIT, 0, PROC_EX_CAST_END, 0, 0, m_attackType, m_spellInfo)); + Unit::ProcDamageAndSpell(ProcSystemArguments(m_caster, procTarget, procAttacker, 0, PROC_EX_CAST_END, 0, 0, m_attackType, m_spellInfo)); } else { - Unit::ProcDamageAndSpell(ProcSystemArguments(m_caster, procTarget, PROC_EX_NORMAL_HIT, 0, PROC_EX_CAST_END, 0, 0, m_attackType, m_spellInfo)); - - // Immediate spell, no big deal + uint32 procAttacker; + uint32 procVictim; + uint32 procEx = PROC_EX_NONE; + PrepareMasksForProcSystem(EFFECT_MASK_ALL, procAttacker, procVictim, m_trueCaster, nullptr); + Unit::ProcDamageAndSpell(ProcSystemArguments(m_caster, procTarget, procAttacker, 0, PROC_EX_CAST_END, 0, 0, m_attackType, m_spellInfo)); handle_immediate(); } diff --git a/src/game/Spells/SpellAuras.cpp b/src/game/Spells/SpellAuras.cpp index 3de01404a1b..2cd50b5d2ec 100755 --- a/src/game/Spells/SpellAuras.cpp +++ b/src/game/Spells/SpellAuras.cpp @@ -978,11 +978,13 @@ bool Aura::CanProcFrom(SpellEntry const* spell, uint32 /*procFlag*/, uint32 Even // Check for extra req (if none) and hit/crit if (EventProcEx == PROC_EX_NONE) { + if ((procEx & PROC_EX_CAST_END) != 0) // cast end does not care about damage/healing + return true; if ((procEx & PROC_EX_ABSORB) && absorbing) // trigger ex absorb procs even if no damage is dealt return true; // No extra req, so can trigger only for active (damage/healing present) and hit/crit - return ((procEx & (PROC_EX_NORMAL_HIT | PROC_EX_CRITICAL_HIT)) && damaging) || (procEx & PROC_EX_CAST_END) != 0; + return ((procEx & (PROC_EX_NORMAL_HIT | PROC_EX_CRITICAL_HIT)) && damaging); } // Passive spells hits here only if resist/reflect/immune/evade // Passive spells can`t trigger if need hit (exclude cases when procExtra include non-active flags)