Skip to content

spellResisted⚓︎

This event triggers when a magic effect has been resisted by an actor, including magic effects from sources like spells, enchantments and potions. This event can trigger multiple times per source, once for each resisted effect.

--- @param e spellResistedEventData
local function spellResistedCallback(e)
end
event.register(tes3.event.spellResisted, spellResistedCallback)

Tip

This event can be filtered based on the reference event data.

Tip

An event can be claimed by setting e.claim to true, or by returning false from the callback. Claiming the event prevents any lower priority callbacks from being called.

Event Data⚓︎

  • caster (tes3reference): Read-only. The caster of the magic source that contained the magic effect. Can be nil.
  • effect (tes3effect): Read-only. The specific effect that triggered the event. This is equal to e.source.effects[e.effectIndex].
  • effectIndex (number): Read-only. The index of the effect in the magic source's effects list.
  • mobile (tes3mobileActor): Read-only. The mobile actor that resisted the magic effect.
  • reference (tes3reference): Read-only. The reference of the mobile actor that resisted the magic effect.
  • source (tes3alchemy, tes3enchantment, tes3spell): Read-only. The magic source that contains the effect.
  • sourceInstance (tes3magicSourceInstance): Read-only. The unique instance of the magic source that contains the effect.
  • target (tes3reference): Read-only. The target of the magic source that contained the magic effect. Can be nil.

Examples⚓︎

Example: Learn resisted spells

Makes actors learn the spell they resisted.

---@param e spellResistedEventData
local function onSpellResisted(e)
    -- We only want this to apply to spells. This event can also trigger for other sources like potions/enchantments.
    if e.source.objectType ~= tes3.objectType.spell then return end

    -- Add the resisted spell to the actor that resisted it.
    tes3.addSpell{
        reference = e.reference,
        spell = e.source --[[@as tes3spell]]
    }

    -- If it is the player that learned the spell, show a message with the name of the spell.
    if e.reference ~= tes3.player then return end
    tes3.messageBox("You learned the '%s' spell.", e.source.name)
end
event.register(tes3.event.spellResisted, onSpellResisted)

absorbedMagicspellResist