diff options
author | Shauren <shauren.trinity@gmail.com> | 2024-12-03 17:40:25 +0100 |
---|---|---|
committer | Shauren <shauren.trinity@gmail.com> | 2024-12-03 17:40:25 +0100 |
commit | 43bf71b3742c6f3ee5f92eb27a6d0c11d1c562c2 (patch) | |
tree | d5232fed653f2d3d6ca9f44bf600c43973c60328 | |
parent | 3c69a40c100f49bb7a348cb729d483e1e8f22947 (diff) |
Core/Spells: Implemented TargetAuraType and ExcludeTargetAuraType cast requirements
-rw-r--r-- | src/server/game/Spells/SpellInfo.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/src/server/game/Spells/SpellInfo.cpp b/src/server/game/Spells/SpellInfo.cpp index 3d56fec4acb..41c9503ab76 100644 --- a/src/server/game/Spells/SpellInfo.cpp +++ b/src/server/game/Spells/SpellInfo.cpp @@ -2344,6 +2344,12 @@ SpellCastResult SpellInfo::CheckTarget(WorldObject const* caster, WorldObject co if (ExcludeTargetAuraSpell && unitTarget->HasAura(ExcludeTargetAuraSpell)) return SPELL_FAILED_TARGET_AURASTATE; + if (TargetAuraType && !unitTarget->HasAuraType(TargetAuraType)) + return SPELL_FAILED_TARGET_AURASTATE; + + if (ExcludeTargetAuraType && unitTarget->HasAuraType(ExcludeTargetAuraType)) + return SPELL_FAILED_TARGET_AURASTATE; + if (unitTarget->HasAuraType(SPELL_AURA_PREVENT_RESURRECTION) && !HasAttribute(SPELL_ATTR7_BYPASS_NO_RESURRECT_AURA)) if (HasEffect(SPELL_EFFECT_SELF_RESURRECT) || HasEffect(SPELL_EFFECT_RESURRECT)) return SPELL_FAILED_TARGET_CANNOT_BE_RESURRECTED; |