diff options
author | Sorikoff <46191832+Sorikoff@users.noreply.github.com> | 2020-04-04 16:29:21 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-04 15:29:21 +0200 |
commit | 264a5839032257f9d65bfad3dd0075d263799d5c (patch) | |
tree | a8926591231d59642307da61a68e254f05958cfa /src | |
parent | a513922fc1572137c4e8b7b75d7ba931b15cf26a (diff) |
Scripts/Pet: Baby Blizzard Bear & Egbert (#24349)
* Baby Blizzard Bear & Egbert
* SQL
* Update 9999_99_99_99_world.sql
SQL fix
* Rename 9999_99_99_99_world.sql to 2020_04_04_00_world.sql
Co-authored-by: Eridium <6587064+Killyana@users.noreply.github.com>
Co-authored-by: Giacomo Pozzoni <giacomopoz@gmail.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/server/scripts/Pet/pet_generic.cpp | 136 |
1 files changed, 0 insertions, 136 deletions
diff --git a/src/server/scripts/Pet/pet_generic.cpp b/src/server/scripts/Pet/pet_generic.cpp index df9aaa09c5c..a811616c981 100644 --- a/src/server/scripts/Pet/pet_generic.cpp +++ b/src/server/scripts/Pet/pet_generic.cpp @@ -21,151 +21,17 @@ */ /* ContentData - npc_pet_gen_baby_blizzard_bear 100% Baby Blizzard Bear sits down occasionally - npc_pet_gen_egbert 100% Egbert run's around npc_pet_gen_pandaren_monk 100% Pandaren Monk drinks and bows with you npc_pet_gen_mojo 100% Mojo follows you when you kiss it EndContentData */ #include "ScriptMgr.h" -#include "DBCStructure.h" -#include "Map.h" #include "MotionMaster.h" #include "ObjectAccessor.h" #include "PassiveAI.h" #include "Player.h" #include "ScriptedCreature.h" -enum BabyBlizzardBearMisc -{ - SPELL_BBB_PET_SIT = 61853, - EVENT_BBB_PET_SIT = 1, - EVENT_BBB_PET_SIT_INTER = 2 -}; - -class npc_pet_gen_baby_blizzard_bear : public CreatureScript -{ -public: - npc_pet_gen_baby_blizzard_bear() : CreatureScript("npc_pet_gen_baby_blizzard_bear") {} - - struct npc_pet_gen_baby_blizzard_bearAI : public NullCreatureAI - { - npc_pet_gen_baby_blizzard_bearAI(Creature* creature) : NullCreatureAI(creature) - { - if (Unit* owner = me->GetCharmerOrOwner()) - me->GetMotionMaster()->MoveFollow(owner, PET_FOLLOW_DIST, me->GetFollowAngle()); - _events.ScheduleEvent(EVENT_BBB_PET_SIT, urandms(10, 30)); - } - - void UpdateAI(uint32 diff) override - { - _events.Update(diff); - - if (Unit* owner = me->GetCharmerOrOwner()) - if (!me->IsWithinDist(owner, 25.f)) - me->InterruptSpell(CURRENT_CHANNELED_SPELL); - - while (uint32 eventId = _events.ExecuteEvent()) - { - switch (eventId) - { - case EVENT_BBB_PET_SIT: - me->CastSpell(me, SPELL_BBB_PET_SIT, false); - _events.ScheduleEvent(EVENT_BBB_PET_SIT_INTER, urandms(15, 30)); - break; - case EVENT_BBB_PET_SIT_INTER: - me->InterruptSpell(CURRENT_CHANNELED_SPELL); - _events.ScheduleEvent(EVENT_BBB_PET_SIT, urandms(10, 30)); - break; - default: - break; - } - } - } - - private: - EventMap _events; - }; - - CreatureAI* GetAI(Creature* creature) const - { - return new npc_pet_gen_baby_blizzard_bearAI(creature); - } -}; - -enum EgbertMisc -{ - SPELL_EGBERT = 40669, - EVENT_RETURN = 3 -}; - -class npc_pet_gen_egbert : public CreatureScript -{ -public: - npc_pet_gen_egbert() : CreatureScript("npc_pet_gen_egbert") {} - - struct npc_pet_gen_egbertAI : public NullCreatureAI - { - npc_pet_gen_egbertAI(Creature* creature) : NullCreatureAI(creature) - { - if (Unit* owner = me->GetCharmerOrOwner()) - if (owner->GetMap()->GetEntry()->addon > 1) - me->SetCanFly(true); - } - - void Reset() override - { - _events.Reset(); - if (Unit* owner = me->GetCharmerOrOwner()) - me->GetMotionMaster()->MoveFollow(owner, PET_FOLLOW_DIST, me->GetFollowAngle()); - } - - void EnterEvadeMode(EvadeReason why) override - { - if (!_EnterEvadeMode(why)) - return; - - Reset(); - } - - void UpdateAI(uint32 diff) override - { - _events.Update(diff); - - if (Unit* owner = me->GetCharmerOrOwner()) - { - if (!me->IsWithinDist(owner, 40.f)) - { - me->RemoveAura(SPELL_EGBERT); - me->GetMotionMaster()->MoveFollow(owner, PET_FOLLOW_DIST, me->GetFollowAngle()); - } - } - - if (me->HasAura(SPELL_EGBERT)) - _events.ScheduleEvent(EVENT_RETURN, urandms(5, 20)); - - while (uint32 eventId = _events.ExecuteEvent()) - { - switch (eventId) - { - case EVENT_RETURN: - me->RemoveAura(SPELL_EGBERT); - break; - default: - break; - } - } - } - private: - EventMap _events; - }; - - CreatureAI* GetAI(Creature* creature) const - { - return new npc_pet_gen_egbertAI(creature); - } -}; - enum PandarenMonkMisc { SPELL_PANDAREN_MONK = 69800, @@ -350,8 +216,6 @@ struct npc_pet_gen_soul_trader : public ScriptedAI void AddSC_generic_pet_scripts() { - new npc_pet_gen_baby_blizzard_bear(); - new npc_pet_gen_egbert(); new npc_pet_gen_pandaren_monk(); new npc_pet_gen_mojo(); RegisterCreatureAI(npc_pet_gen_soul_trader); |