diff options
-rw-r--r-- | sql/updates/world/master/2022_01_12_02_world_hunter_murder_of_crows.sql | 2 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_hunter.cpp | 48 |
2 files changed, 50 insertions, 0 deletions
diff --git a/sql/updates/world/master/2022_01_12_02_world_hunter_murder_of_crows.sql b/sql/updates/world/master/2022_01_12_02_world_hunter_murder_of_crows.sql new file mode 100644 index 00000000000..33be2a705a8 --- /dev/null +++ b/sql/updates/world/master/2022_01_12_02_world_hunter_murder_of_crows.sql @@ -0,0 +1,2 @@ +DELETE FROM `spell_script_names` WHERE `ScriptName` = 'spell_hun_a_murder_of_crows'; +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES (131894, 'spell_hun_a_murder_of_crows'); diff --git a/src/server/scripts/Spells/spell_hunter.cpp b/src/server/scripts/Spells/spell_hunter.cpp index dae411c3046..e3be7cf78ed 100644 --- a/src/server/scripts/Spells/spell_hunter.cpp +++ b/src/server/scripts/Spells/spell_hunter.cpp @@ -32,6 +32,10 @@ enum HunterSpells { + SPELL_HUNTER_A_MURDER_OF_CROWS_DAMAGE = 131900, + SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_1 = 131637, + SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_2 = 131951, + SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_3 = 131952, SPELL_HUNTER_ASPECT_CHEETAH_SLOW = 186258, SPELL_HUNTER_EXHILARATION = 109304, SPELL_HUNTER_EXHILARATION_PET = 128594, @@ -57,6 +61,49 @@ enum MiscSpells SPELL_SHAMAN_SATED = 57724 }; +// 131894 - A Murder of Crows +class spell_hun_a_murder_of_crows : public AuraScript +{ + PrepareAuraScript(spell_hun_a_murder_of_crows); + + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo + ({ + SPELL_HUNTER_A_MURDER_OF_CROWS_DAMAGE, + SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_1, + SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_2, + SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_3 + }); + } + + void HandleDummyTick(AuraEffect const* /*aurEff*/) + { + Unit* target = GetTarget(); + + if (Unit* caster = GetCaster()) + caster->CastSpell(target, SPELL_HUNTER_A_MURDER_OF_CROWS_DAMAGE, true); + + target->CastSpell(target, SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_1, true); + target->CastSpell(target, SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_2, true); + target->CastSpell(target, SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_3, true); + target->CastSpell(target, SPELL_HUNTER_A_MURDER_OF_CROWS_VISUAL_3, true); // not a mistake, it is intended to cast twice + } + + void RemoveEffect(AuraEffect const* /*aurEff*/, AuraEffectHandleModes /*mode*/) + { + if (GetTargetApplication()->GetRemoveMode() == AURA_REMOVE_BY_DEATH) + if (Unit* caster = GetCaster()) + caster->GetSpellHistory()->ResetCooldown(GetId(), true); + } + + void Register() override + { + OnEffectPeriodic += AuraEffectPeriodicFn(spell_hun_a_murder_of_crows::HandleDummyTick, EFFECT_0, SPELL_AURA_PERIODIC_DUMMY); + OnEffectRemove += AuraEffectRemoveFn(spell_hun_a_murder_of_crows::RemoveEffect, EFFECT_0, SPELL_AURA_PERIODIC_DUMMY, AURA_EFFECT_HANDLE_REAL); + } +}; + // 186257 - Aspect of the Cheetah class spell_hun_aspect_cheetah : public SpellScriptLoader { @@ -655,6 +702,7 @@ public: void AddSC_hunter_spell_scripts() { + RegisterAuraScript(spell_hun_a_murder_of_crows); new spell_hun_aspect_cheetah(); new spell_hun_exhilaration(); new spell_hun_hunting_party(); |