From 9186c696d4a82d06018606378f9264eff01fb0f2 Mon Sep 17 00:00:00 2001 From: killerwife Date: Fri, 23 Aug 2024 10:36:22 +0200 Subject: [PATCH] Icecrown: Add custom error and reagent consumption to summon spells --- .../scripts/northrend/icecrown.cpp | 28 +++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/src/game/AI/ScriptDevAI/scripts/northrend/icecrown.cpp b/src/game/AI/ScriptDevAI/scripts/northrend/icecrown.cpp index a909e24e8df..374d128b553 100644 --- a/src/game/AI/ScriptDevAI/scripts/northrend/icecrown.cpp +++ b/src/game/AI/ScriptDevAI/scripts/northrend/icecrown.cpp @@ -1160,22 +1160,46 @@ struct RodOfSiphoning : public AuraScript }; // 60561 - Summon Dark Messenger Beam -struct SummonDarkMessengerBeam : public AuraScript +struct SummonDarkMessengerBeam : public SpellScript, public AuraScript { + SpellCastResult OnCheckCast(Spell* spell, bool /*strict*/) const override + { + if (spell->GetCaster()->IsPlayer()) + { + Player* player = static_cast(spell->GetCaster()); + if (!player->HasItemCount(44434, 5)) + { + return SPELL_FAILED_REAGENTS; + } + } + return SPELL_CAST_OK; + } + + void OnSpellCastResultOverride(SpellCastResult& result, uint32& param1, uint32& param2) const override + { + if (result == SPELL_FAILED_REAGENTS) + { + result = SPELL_FAILED_CUSTOM_ERROR; + param1 = SPELL_FAILED_CUSTOM_ERROR_55; + } + } + void OnPeriodicTrigger(Aura* aura, PeriodicTriggerData& data) const override { data.caster = aura->GetCaster(); data.target = nullptr; + data.triggerFlags |= TRIGGERED_FORCE_COSTS; } }; // 60831 - Alumeth's Remains -struct AlumethsRemains : public AuraScript +struct AlumethsRemains : public SpellScript, public AuraScript { void OnPeriodicTrigger(Aura* aura, PeriodicTriggerData& data) const override { data.caster = aura->GetCaster(); data.target = nullptr; + data.triggerFlags |= TRIGGERED_FORCE_COSTS; } };