diff options
Diffstat (limited to 'src/server/scripts')
| -rw-r--r-- | src/server/scripts/Commands/cs_npc.cpp | 4 | ||||
| -rw-r--r-- | src/server/scripts/EasternKingdoms/stormwind_city.cpp | 74 | ||||
| -rw-r--r-- | src/server/scripts/Northrend/dalaran.cpp | 13 | ||||
| -rw-r--r-- | src/server/scripts/Spells/spell_generic.cpp | 78 | 
4 files changed, 90 insertions, 79 deletions
| diff --git a/src/server/scripts/Commands/cs_npc.cpp b/src/server/scripts/Commands/cs_npc.cpp index 1b6a6c6fdcf..57932ef56c6 100644 --- a/src/server/scripts/Commands/cs_npc.cpp +++ b/src/server/scripts/Commands/cs_npc.cpp @@ -130,7 +130,7 @@ public:          {              uint32 tguid = chr->GetTransport()->AddNPCPassenger(0, id, chr->GetTransOffsetX(), chr->GetTransOffsetY(), chr->GetTransOffsetZ(), chr->GetTransOffsetO());              if (tguid > 0) -                WorldDatabase.PQuery("INSERT INTO creature_transport (guid, npc_entry, transport_entry,  TransOffsetX, TransOffsetY, TransOffsetZ, TransOffsetO) values (%u, %u, %f, %f, %f, %f, %u)", tguid, id, chr->GetTransport()->GetEntry(), chr->GetTransOffsetX(), chr->GetTransOffsetY(), chr->GetTransOffsetZ(), chr->GetTransOffsetO()); +                WorldDatabase.PExecute("INSERT INTO creature_transport (guid, npc_entry, transport_entry,  TransOffsetX, TransOffsetY, TransOffsetZ, TransOffsetO) values (%u, %u, %f, %f, %f, %f, %u)", tguid, id, chr->GetTransport()->GetEntry(), chr->GetTransOffsetX(), chr->GetTransOffsetY(), chr->GetTransOffsetZ(), chr->GetTransOffsetO());              return true;          } @@ -679,7 +679,7 @@ public:          if (target->GetTransport())              if (target->GetGUIDTransport()) -                WorldDatabase.PQuery("UPDATE creature_transport SET emote=%u WHERE transport_entry=%u AND guid=%u", emote, target->GetTransport()->GetEntry(), target->GetGUIDTransport()); +                WorldDatabase.PExecute("UPDATE creature_transport SET emote=%u WHERE transport_entry=%u AND guid=%u", emote, target->GetTransport()->GetEntry(), target->GetGUIDTransport());          target->SetUInt32Value(UNIT_NPC_EMOTESTATE, emote); diff --git a/src/server/scripts/EasternKingdoms/stormwind_city.cpp b/src/server/scripts/EasternKingdoms/stormwind_city.cpp index 4d43e4adefe..a4eca1950f8 100644 --- a/src/server/scripts/EasternKingdoms/stormwind_city.cpp +++ b/src/server/scripts/EasternKingdoms/stormwind_city.cpp @@ -26,7 +26,6 @@ EndScriptData */  /* ContentData  npc_archmage_malin  npc_bartleby -npc_dashel_stonefist  npc_lady_katrana_prestor  npc_tyrion  npc_tyrion_spybot @@ -148,78 +147,6 @@ public:  };  /*###### -## npc_dashel_stonefist -######*/ - -enum eDashel -{ -    QUEST_MISSING_DIPLO_PT8     = 1447, -    FACTION_HOSTILE             = 168 -}; - -class npc_dashel_stonefist : public CreatureScript -{ -public: -    npc_dashel_stonefist() : CreatureScript("npc_dashel_stonefist") { } - -    bool OnQuestAccept(Player* player, Creature* creature, Quest const* quest) -    { -        if (quest->GetQuestId() == QUEST_MISSING_DIPLO_PT8) -        { -            creature->setFaction(FACTION_HOSTILE); -            CAST_AI(npc_dashel_stonefist::npc_dashel_stonefistAI, creature->AI())->AttackStart(player); -        } -        return true; -    } - -    CreatureAI* GetAI(Creature* creature) const -    { -        return new npc_dashel_stonefistAI(creature); -    } - -    struct npc_dashel_stonefistAI : public ScriptedAI -    { -        npc_dashel_stonefistAI(Creature* c) : ScriptedAI(c) -        { -            m_uiNormalFaction = c->getFaction(); -        } - -        uint32 m_uiNormalFaction; - -        void Reset() -        { -            if (me->getFaction() != m_uiNormalFaction) -                me->setFaction(m_uiNormalFaction); -        } - -        void AttackedBy(Unit* pAttacker) -        { -            if (me->getVictim()) -                return; - -            if (me->IsFriendlyTo(pAttacker)) -                return; - -            AttackStart(pAttacker); -        } - -        void DamageTaken(Unit* pDoneBy, uint32 &uiDamage) -        { -            if (uiDamage > me->GetHealth() || me->HealthBelowPctDamaged(15, uiDamage)) -            { -                uiDamage = 0; - -                if (pDoneBy->GetTypeId() == TYPEID_PLAYER) -                    CAST_PLR(pDoneBy)->AreaExploredOrEventHappens(QUEST_MISSING_DIPLO_PT8); - -                EnterEvadeMode(); -            } -        } -    }; - -}; - -/*######  ## npc_lady_katrana_prestor  ######*/ @@ -716,7 +643,6 @@ void AddSC_stormwind_city()  {      new npc_archmage_malin();      new npc_bartleby(); -    new npc_dashel_stonefist();      new npc_lady_katrana_prestor();      new npc_tyrion();      new npc_tyrion_spybot(); diff --git a/src/server/scripts/Northrend/dalaran.cpp b/src/server/scripts/Northrend/dalaran.cpp index 57007a93fa7..cd3cbf29d0d 100644 --- a/src/server/scripts/Northrend/dalaran.cpp +++ b/src/server/scripts/Northrend/dalaran.cpp @@ -32,7 +32,12 @@ Script Data End */  enum Spells  {      SPELL_TRESPASSER_A = 54028, -    SPELL_TRESPASSER_H = 54029 +    SPELL_TRESPASSER_H = 54029, + +    SPELL_SUNREAVER_DISGUISE_FEMALE        = 70973, +    SPELL_SUNREAVER_DISGUISE_MALE          = 70974, +    SPELL_SILVER_COVENANT_DISGUISE_FEMALE  = 70971, +    SPELL_SILVER_COVENANT_DISGUISE_MALE    = 70972,  };  enum NPCs // All outdoor guards are within 35.0f of these NPCs @@ -71,8 +76,10 @@ public:              Player* player = who->GetCharmerOrOwnerPlayerOrPlayerItself(); -            // If player has Disguise aura for quest A Meeting With The Magister or An Audience With The Arcanist, do not teleport it away but let it pass -            if (!player || player->isGameMaster() || player->IsBeingTeleported() || player->HasAura(70973) || player->HasAura(70971)) +            if (!player || player->isGameMaster() || player->IsBeingTeleported() || +                // If player has Disguise aura for quest A Meeting With The Magister or An Audience With The Arcanist, do not teleport it away but let it pass +                player->HasAura(SPELL_SUNREAVER_DISGUISE_FEMALE) || player->HasAura(SPELL_SUNREAVER_DISGUISE_MALE) || +                player->HasAura(SPELL_SILVER_COVENANT_DISGUISE_FEMALE) || player->HasAura(SPELL_SILVER_COVENANT_DISGUISE_MALE))                  return;              switch (me->GetEntry()) diff --git a/src/server/scripts/Spells/spell_generic.cpp b/src/server/scripts/Spells/spell_generic.cpp index 3fb2c4f3319..2b31a50510d 100644 --- a/src/server/scripts/Spells/spell_generic.cpp +++ b/src/server/scripts/Spells/spell_generic.cpp @@ -1481,6 +1481,82 @@ class spell_gen_luck_of_the_draw : public SpellScriptLoader          }  }; +enum DalaranDisguiseSpells +{ +    SPELL_SUNREAVER_DISGUISE_TRIGGER       = 69672, +    SPELL_SUNREAVER_DISGUISE_FEMALE        = 70973, +    SPELL_SUNREAVER_DISGUISE_MALE          = 70974, + +    SPELL_SILVER_COVENANT_DISGUISE_TRIGGER = 69673, +    SPELL_SILVER_COVENANT_DISGUISE_FEMALE  = 70971, +    SPELL_SILVER_COVENANT_DISGUISE_MALE    = 70972, +}; + +class spell_gen_dalaran_disguise : public SpellScriptLoader +{ +    public: +        spell_gen_dalaran_disguise(const char* name) : SpellScriptLoader(name) {} + +        class spell_gen_dalaran_disguise_SpellScript : public SpellScript +        { +            PrepareSpellScript(spell_gen_dalaran_disguise_SpellScript); +            bool Validate(SpellInfo const* spellEntry) +            { +                switch (spellEntry->Id) +                { +                    case SPELL_SUNREAVER_DISGUISE_TRIGGER: +                        if (!sSpellMgr->GetSpellInfo(SPELL_SUNREAVER_DISGUISE_FEMALE)) +                            return false; +                        if (!sSpellMgr->GetSpellInfo(SPELL_SUNREAVER_DISGUISE_MALE)) +                            return false; +                        break; +                    case SPELL_SILVER_COVENANT_DISGUISE_TRIGGER: +                        if (!sSpellMgr->GetSpellInfo(SPELL_SILVER_COVENANT_DISGUISE_FEMALE)) +                            return false; +                        if (!sSpellMgr->GetSpellInfo(SPELL_SILVER_COVENANT_DISGUISE_MALE)) +                            return false; +                        break; +                } +                return true; +            } + +            void HandleScript(SpellEffIndex /*effIndex*/) +            { + +                if (Player* player = GetHitPlayer()) +                { +                    uint8 gender = player->getGender(); + +                    uint32 spellId = GetSpellInfo()->Id; + +                    switch (spellId) +                    { +                        case SPELL_SUNREAVER_DISGUISE_TRIGGER: +                            spellId = gender ? SPELL_SUNREAVER_DISGUISE_FEMALE : SPELL_SUNREAVER_DISGUISE_MALE; +                            break; +                        case SPELL_SILVER_COVENANT_DISGUISE_TRIGGER: +                            spellId = gender ? SPELL_SILVER_COVENANT_DISGUISE_FEMALE : SPELL_SILVER_COVENANT_DISGUISE_MALE; +                            break; +                        default: +                            break; +                    } + +                    GetCaster()->CastSpell(player, spellId, true); +                } +            } + +            void Register() +            { +                OnEffectHitTarget += SpellEffectFn(spell_gen_dalaran_disguise_SpellScript::HandleScript, EFFECT_0, SPELL_EFFECT_SCRIPT_EFFECT); +            } +        }; + +        SpellScript* GetSpellScript() const +        { +            return new spell_gen_dalaran_disguise_SpellScript(); +        } +}; +  void AddSC_generic_spell_scripts()  {      new spell_gen_absorb0_hitlimit1(); @@ -1514,4 +1590,6 @@ void AddSC_generic_spell_scripts()      new spell_gen_oracle_wolvar_reputation();      new spell_gen_damage_reduction_aura();      new spell_gen_luck_of_the_draw(); +    new spell_gen_dalaran_disguise("spell_gen_sunreaver_disguise"); +    new spell_gen_dalaran_disguise("spell_gen_silver_covenant_disguise");  } | 
