diff options
| -rw-r--r-- | sql/updates/world/2015_02_06_14_world.sql | 9 | ||||
| -rw-r--r-- | src/server/scripts/Northrend/zone_grizzly_hills.cpp | 39 | 
2 files changed, 48 insertions, 0 deletions
diff --git a/sql/updates/world/2015_02_06_14_world.sql b/sql/updates/world/2015_02_06_14_world.sql new file mode 100644 index 00000000000..29dd214f262 --- /dev/null +++ b/sql/updates/world/2015_02_06_14_world.sql @@ -0,0 +1,9 @@ +--  assign spellscript for Spell: 'Infected Worgen Bite' + +DELETE FROM `spell_linked_spell` WHERE `spell_trigger`=53095; +INSERT INTO `spell_linked_spell` (`spell_trigger`, `spell_effect`, `type`, `comment`) VALUES +(53095,-53094,2,'Infected Worgen Bite - Worgen\'s Call Immunity'); + +DELETE FROM `spell_script_names` WHERE `spell_id`=53094; +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES +(53094,'spell_infected_worgen_bite'); diff --git a/src/server/scripts/Northrend/zone_grizzly_hills.cpp b/src/server/scripts/Northrend/zone_grizzly_hills.cpp index dad71ab0c24..15fa6d836cd 100644 --- a/src/server/scripts/Northrend/zone_grizzly_hills.cpp +++ b/src/server/scripts/Northrend/zone_grizzly_hills.cpp @@ -816,6 +816,44 @@ class spell_shredder_delivery : public SpellScriptLoader          }  }; +enum InfectedWorgenBite +{ +    SPELL_INFECTED_WORGEN_BITE = 53094, +    SPELL_WORGENS_CALL         = 53095 +}; + +class spell_infected_worgen_bite : public SpellScriptLoader +{ +    public: +        spell_infected_worgen_bite() : SpellScriptLoader("spell_infected_worgen_bite") { } +         +        class spell_infected_worgen_bite_AuraScript : public AuraScript +        { +            PrepareAuraScript(spell_infected_worgen_bite_AuraScript); +             +            void HandleAfterEffectApply(AuraEffect const* /*aurEff*/, AuraEffectHandleModes /*mode*/) +            { +                Unit* target = GetTarget(); +                if (target->GetTypeId() == TYPEID_PLAYER) +                    if (GetStackAmount() == GetSpellInfo()->StackAmount) +                    { +                        Remove(); +                        target->CastSpell(target, SPELL_WORGENS_CALL, true); +                    } +            } +             +            void Register() override +            { +                AfterEffectApply += AuraEffectApplyFn(spell_infected_worgen_bite_AuraScript::HandleAfterEffectApply, EFFECT_1, SPELL_AURA_PERIODIC_DAMAGE, AURA_EFFECT_HANDLE_REAPPLY); +            } +        }; + +        AuraScript* GetAuraScript() const override +        { +            return new spell_infected_worgen_bite_AuraScript(); +        } +}; +  void AddSC_grizzly_hills()  {      new npc_emily(); @@ -827,4 +865,5 @@ void AddSC_grizzly_hills()      new npc_venture_co_straggler();      new npc_lake_frog();      new spell_shredder_delivery(); +    new spell_infected_worgen_bite();  }  | 
