diff options
-rw-r--r-- | sql/updates/world/2013_06_16_00_world_spell_script_names_434.sql | 5 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_shaman.cpp | 78 |
2 files changed, 83 insertions, 0 deletions
diff --git a/sql/updates/world/2013_06_16_00_world_spell_script_names_434.sql b/sql/updates/world/2013_06_16_00_world_spell_script_names_434.sql new file mode 100644 index 00000000000..de5fa8f4956 --- /dev/null +++ b/sql/updates/world/2013_06_16_00_world_spell_script_names_434.sql @@ -0,0 +1,5 @@ +DELETE FROM `spell_script_names` WHERE `spell_id` IN (77755,77756,77762); +INSERT INTO `spell_script_names`(`spell_id`, `ScriptName`) VALUES +(77755, 'spell_sha_lava_surge'), +(77756, 'spell_sha_lava_surge'), +(77762, 'spell_sha_lava_surge_proc'); diff --git a/src/server/scripts/Spells/spell_shaman.cpp b/src/server/scripts/Spells/spell_shaman.cpp index 045227a8f99..db24d860a3e 100644 --- a/src/server/scripts/Spells/spell_shaman.cpp +++ b/src/server/scripts/Spells/spell_shaman.cpp @@ -42,8 +42,10 @@ enum ShamanSpells SPELL_SHAMAN_GLYPH_OF_HEALING_STREAM_TOTEM = 55456, SPELL_SHAMAN_GLYPH_OF_MANA_TIDE = 55441, SPELL_SHAMAN_GLYPH_OF_THUNDERSTORM = 62132, + SPELL_SHAMAN_LAVA_BURST = 51505, SPELL_SHAMAN_LAVA_FLOWS_R1 = 51480, SPELL_SHAMAN_LAVA_FLOWS_TRIGGERED_R1 = 65264, + SPELL_SHAMAN_LAVA_SURGE = 77762, SPELL_SHAMAN_SATED = 57724, SPELL_SHAMAN_STORM_EARTH_AND_FIRE = 51483, SPELL_SHAMAN_TOTEM_EARTHBIND_EARTHGRAB = 64695, @@ -585,6 +587,80 @@ class spell_sha_lava_lash : public SpellScriptLoader } }; +class spell_sha_lava_surge : public SpellScriptLoader +{ + public: + spell_sha_lava_surge() : SpellScriptLoader("spell_sha_lava_surge") { } + + class spell_sha_lava_surge_AuraScript : public AuraScript + { + PrepareAuraScript(spell_sha_lava_surge_AuraScript); + + bool Validate(SpellInfo const* /*spellInfo*/) + { + if (!sSpellMgr->GetSpellInfo(SPELL_SHAMAN_LAVA_SURGE)) + return false; + return true; + } + + void HandleEffectProc(AuraEffect const* /*aurEff*/, ProcEventInfo& /*eventInfo*/) + { + PreventDefaultAction(); // will prevent default effect execution + + GetTarget()->CastSpell(GetTarget(), SPELL_SHAMAN_LAVA_SURGE, true); + } + + void Register() + { + OnEffectProc += AuraEffectProcFn(spell_sha_lava_surge_AuraScript::HandleEffectProc, EFFECT_0, SPELL_AURA_DUMMY); + } + }; + + AuraScript* GetAuraScript() const + { + return new spell_sha_lava_surge_AuraScript(); + } +}; + +class spell_sha_lava_surge_proc : public SpellScriptLoader +{ + public: + spell_sha_lava_surge_proc() : SpellScriptLoader("spell_sha_lava_surge_proc") { } + + class spell_sha_lava_surge_proc_SpellScript : public SpellScript + { + PrepareSpellScript(spell_sha_lava_surge_proc_SpellScript) + + bool Validate(SpellInfo const* /*spellInfo*/) + { + if (!sSpellMgr->GetSpellInfo(SPELL_SHAMAN_LAVA_BURST)) + return false; + return true; + } + + bool Load() + { + return GetCaster()->GetTypeId() == TYPEID_PLAYER; + } + + void HandleDummy(SpellEffIndex /*effIndex*/) + { + GetCaster()->ToPlayer()->RemoveSpellCooldown(SPELL_SHAMAN_LAVA_BURST, true); + } + + void Register() + { + OnEffectHitTarget += SpellEffectFn(spell_sha_lava_surge_proc_SpellScript::HandleDummy, EFFECT_0, SPELL_EFFECT_DUMMY); + } + + }; + + SpellScript* GetSpellScript() const + { + return new spell_sha_lava_surge_proc_SpellScript(); + } +}; + // 16191 - Mana Tide /// Updated 4.3.4 class spell_sha_mana_tide_totem : public SpellScriptLoader @@ -658,6 +734,8 @@ void AddSC_shaman_spell_scripts() new spell_sha_healing_stream_totem(); new spell_sha_heroism(); new spell_sha_lava_lash(); + new spell_sha_lava_surge(); + new spell_sha_lava_surge_proc(); new spell_sha_mana_tide_totem(); new spell_sha_thunderstorm(); } |