diff options
author | Aqua Deus <95978183+aquadeus@users.noreply.github.com> | 2024-12-29 21:04:04 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-29 21:04:04 +0100 |
commit | c197a59eb394d8c9dfb932e9cfd60787cc81746d (patch) | |
tree | 8a785c76c9a1e5a48dffe12d1452a1b42b4cdc67 | |
parent | 5e541de5747b26270da90d0d3c60de96a518a5b9 (diff) |
Scripts/Spells: Implement demon hunter talent "Last Resort" (#30500)
-rw-r--r-- | sql/updates/world/master/2024_12_29_03_world.sql | 3 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_dh.cpp | 35 |
2 files changed, 38 insertions, 0 deletions
diff --git a/sql/updates/world/master/2024_12_29_03_world.sql b/sql/updates/world/master/2024_12_29_03_world.sql new file mode 100644 index 00000000000..1e04cd19ac6 --- /dev/null +++ b/sql/updates/world/master/2024_12_29_03_world.sql @@ -0,0 +1,3 @@ +DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_dh_last_resort'; +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES +(209258, 'spell_dh_last_resort'); diff --git a/src/server/scripts/Spells/spell_dh.cpp b/src/server/scripts/Spells/spell_dh.cpp index 54df607a267..1820cae34eb 100644 --- a/src/server/scripts/Spells/spell_dh.cpp +++ b/src/server/scripts/Spells/spell_dh.cpp @@ -727,6 +727,40 @@ class spell_dh_furious_gaze : public AuraScript } }; +// 209258 - Last Resort +class spell_dh_last_resort : public AuraScript +{ + bool Validate(SpellInfo const* spellInfo) override + { + return ValidateSpellInfo({ SPELL_DH_UNCONTAINED_FEL, SPELL_DH_METAMORPHOSIS_VENGEANCE_TRANSFORM }) + && ValidateSpellEffect({ { spellInfo->Id, EFFECT_1 } }); + } + + void HandleAbsorb(AuraEffect const* /*aurEff*/, DamageInfo const& /*dmgInfo*/, uint32& absorbAmount) + { + Unit* target = GetTarget(); + if (target->HasAura(SPELL_DH_UNCONTAINED_FEL)) + { + absorbAmount = 0; + return; + } + + PreventDefaultAction(); + + CastSpellExtraArgs castArgs = TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR | TRIGGERED_IGNORE_SPELL_AND_CATEGORY_CD; + + target->CastSpell(target, SPELL_DH_METAMORPHOSIS_VENGEANCE_TRANSFORM, castArgs); + target->CastSpell(target, SPELL_DH_UNCONTAINED_FEL, castArgs); + + target->SetHealth(target->CountPctFromMaxHealth(GetEffectInfo(EFFECT_1).CalcValue(target))); + } + + void Register() override + { + OnEffectAbsorb += AuraEffectAbsorbOverkillFn(spell_dh_last_resort::HandleAbsorb, EFFECT_0); + } +}; + // 188499 - Blade Dance // 210152 - Death Sweep class spell_dh_blade_dance : public SpellScript @@ -1058,6 +1092,7 @@ void AddSC_demon_hunter_spell_scripts() RegisterSpellScript(spell_dh_felblade_charge); RegisterSpellScript(spell_dh_felblade_cooldown_reset_proc); RegisterSpellScript(spell_dh_furious_gaze); + RegisterSpellScript(spell_dh_last_resort); RegisterSpellScript(spell_dh_sigil_of_chains); RegisterSpellScript(spell_dh_tactical_retreat); RegisterSpellScript(spell_dh_vengeful_retreat_damage); |