diff options
author | Blaymoira <none@none> | 2008-12-27 21:29:09 +0100 |
---|---|---|
committer | Blaymoira <none@none> | 2008-12-27 21:29:09 +0100 |
commit | b086817814457f53cdcac6c02d9dcd4e1c60a35f (patch) | |
tree | 6f56a051c41fcc142c18f07f0c227a7570cc66ed /src | |
parent | 89f66acc87ac61e710742b154b3568ad1bf38517 (diff) |
*Support for quest 665
--HG--
branch : trunk
Diffstat (limited to 'src')
-rw-r--r-- | src/bindings/scripts/Makefile.am | 1 | ||||
-rw-r--r-- | src/bindings/scripts/ScriptMgr.cpp | 4 | ||||
-rw-r--r-- | src/bindings/scripts/VC71/71ScriptDev2.vcproj | 4 | ||||
-rw-r--r-- | src/bindings/scripts/VC80/80ScriptDev2.vcproj | 4 | ||||
-rw-r--r-- | src/bindings/scripts/VC90/90ScriptDev2.vcproj | 4 | ||||
-rw-r--r-- | src/bindings/scripts/scripts/zone/arathi_highlands/arathi_highlands.cpp | 152 |
6 files changed, 169 insertions, 0 deletions
diff --git a/src/bindings/scripts/Makefile.am b/src/bindings/scripts/Makefile.am index 2789b2a51b7..7086664d0ac 100644 --- a/src/bindings/scripts/Makefile.am +++ b/src/bindings/scripts/Makefile.am @@ -69,6 +69,7 @@ scripts/npc/npc_innkeeper.cpp \ scripts/npc/npc_professions.cpp \ scripts/npc/npcs_special.cpp \ scripts/zone/alterac_mountains/alterac_mountains.cpp \ +scripts/zone/arathi_highlands/arathi_highlands.cpp \ scripts/zone/ashenvale_forest/ashenvale.cpp\ scripts/zone/aunchindoun/auchenai_crypts/boss_exarch_maladaar.cpp \ scripts/zone/aunchindoun/mana_tombs/boss_nexusprince_shaffar.cpp \ diff --git a/src/bindings/scripts/ScriptMgr.cpp b/src/bindings/scripts/ScriptMgr.cpp index 76ad10fe6b3..3b29f9ddf8f 100644 --- a/src/bindings/scripts/ScriptMgr.cpp +++ b/src/bindings/scripts/ScriptMgr.cpp @@ -108,6 +108,8 @@ extern void AddSC_npcs_special(); extern void AddSC_alterac_mountains(); //Arathi Highlands +extern void AddSC_arathi_highlands(); + //Ashenvale Forest extern void AddSC_ashenvale(); @@ -1304,6 +1306,8 @@ void ScriptsInit() AddSC_alterac_mountains(); //Arathi Highlands + AddSC_arathi_highlands(); + //Ashenvale Forest AddSC_ashenvale(); diff --git a/src/bindings/scripts/VC71/71ScriptDev2.vcproj b/src/bindings/scripts/VC71/71ScriptDev2.vcproj index 8eb464b81c8..d0cd6592152 100644 --- a/src/bindings/scripts/VC71/71ScriptDev2.vcproj +++ b/src/bindings/scripts/VC71/71ScriptDev2.vcproj @@ -372,6 +372,10 @@ <Filter Name="Arathi Highlands" > + <File + RelativePath="..\scripts\zone\arathi_highlands\arathi_highlands.cpp" + > + </File> </Filter> <Filter Name="Deadmines" diff --git a/src/bindings/scripts/VC80/80ScriptDev2.vcproj b/src/bindings/scripts/VC80/80ScriptDev2.vcproj index f07fc80900e..d82a8bf0087 100644 --- a/src/bindings/scripts/VC80/80ScriptDev2.vcproj +++ b/src/bindings/scripts/VC80/80ScriptDev2.vcproj @@ -549,6 +549,10 @@ <Filter Name="Arathi Highlands" > + <File + RelativePath="..\scripts\zone\arathi_highlands\arathi_highlands.cpp" + > + </File> </Filter> <Filter Name="Deadmines" diff --git a/src/bindings/scripts/VC90/90ScriptDev2.vcproj b/src/bindings/scripts/VC90/90ScriptDev2.vcproj index 613ba6fa3c8..49debbd79bf 100644 --- a/src/bindings/scripts/VC90/90ScriptDev2.vcproj +++ b/src/bindings/scripts/VC90/90ScriptDev2.vcproj @@ -542,6 +542,10 @@ <Filter Name="Arathi Highlands" > + <File + RelativePath="..\scripts\zone\arathi_highlands\arathi_highlands.cpp" + > + </File> </Filter> <Filter Name="Deadmines" diff --git a/src/bindings/scripts/scripts/zone/arathi_highlands/arathi_highlands.cpp b/src/bindings/scripts/scripts/zone/arathi_highlands/arathi_highlands.cpp new file mode 100644 index 00000000000..92dcb34a433 --- /dev/null +++ b/src/bindings/scripts/scripts/zone/arathi_highlands/arathi_highlands.cpp @@ -0,0 +1,152 @@ +/* Copyright (C) 2006 - 2008 ScriptDev2 <https://scriptdev2.svn.sourceforge.net/> + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +/* ScriptData +SDName: Arathi Highlands +SD%Complete: 100 +SDComment: Quest support: 665 +SDCategory: Arathi Highlands +EndScriptData */ + +/* ContentData +npc_professor_phizzlethorpe +EndContentData */ + +#include "precompiled.h" +#include "../../npc/npc_escortAI.h" + +/*###### +## npc_professor_phizzlethorpe +######*/ + +#define SAY_PROGRESS_1 "Ok, $N. Follow me to the cave where I'll attempt to harness the power of the rune stone into these goggles." +#define SAY_PROGRESS_2 "I discovered this cave on our first day here. I believe the energy in the stone can be used to our advantage." +#define SAY_PROGRESS_3 "I'll begin drawing energy from the stone. Your job, $N, i to defend me. This place is cursed... trust me." +#define EMOTE_PROGRESS_4 "begins tinkering with the goggles before the stone." +#define SAY_AGGRO "Help!!! Get these things off me so I can get my work done!" +#define SAY_PROGRESS_5 "Almost done! Just a little longer!" +#define SAY_PROGRESS_6 "I've done it! I have harnessed the power of the stone into the goggles! Let's get out of here!" +#define SAY_PROGRESS_7 "Phew! Glad to be back from that creepy cave." +#define EMOTE_PROGRESS_8 "hands one glowing goggles over to Doctor Draxlegauge." +#define SAY_PROGRESS_9 "Doctor Draxlegauge will give you further instructions, $N. Many thanks for your help!" + +#define QUEST_SUNKEN_TREASURE 665 +#define MOB_VENGEFUL_SURGE 2776 + +struct TRINITY_DLL_DECL npc_professor_phizzlethorpeAI : public npc_escortAI +{ + npc_professor_phizzlethorpeAI(Creature *c) : npc_escortAI(c) {Reset();} + + void WaypointReached(uint32 i) + { + Unit* player = Unit::GetUnit((*m_creature), PlayerGUID); + + switch(i) + { + case 4:DoSay(SAY_PROGRESS_2, LANG_UNIVERSAL, player, true);break; + case 5:DoSay(SAY_PROGRESS_3, LANG_UNIVERSAL, player, true);break; + case 8:DoTextEmote(EMOTE_PROGRESS_4, NULL);break; + case 9: + { + Creature* sum1 = m_creature->SummonCreature(MOB_VENGEFUL_SURGE, -2052.96, -2142.49, 20.15, 1.0f, TEMPSUMMON_DEAD_DESPAWN, 0); + Creature* sum2 = m_creature->SummonCreature(MOB_VENGEFUL_SURGE, -2052.96, -2142.49, 20.15, 1.0f, TEMPSUMMON_DEAD_DESPAWN, 0); + sum1->Attack(m_creature, true); + sum2->Attack(m_creature, true); + break; + } + case 10:DoSay(SAY_PROGRESS_5, LANG_UNIVERSAL, player, true);break; + case 11:DoSay(SAY_PROGRESS_6, LANG_UNIVERSAL, player, true);break; + case 19:DoSay(SAY_PROGRESS_7, LANG_UNIVERSAL, player, true); break; + case 20: + DoTextEmote(EMOTE_PROGRESS_8, NULL); + DoSay(SAY_PROGRESS_9, LANG_UNIVERSAL, player, true); + ((Player*)player)->GroupEventHappens(QUEST_SUNKEN_TREASURE, m_creature); + break; + } + } + + void Reset(){} + + void Aggro(Unit* who) + { + DoSay(SAY_AGGRO, LANG_UNIVERSAL, NULL); + } + + void JustDied(Unit* killer) + { + if (PlayerGUID) + { + Unit* player = Unit::GetUnit((*m_creature), PlayerGUID); + if (player) + ((Player*)player)->FailQuest(QUEST_SUNKEN_TREASURE); + } + } + + void UpdateAI(const uint32 diff) + { + npc_escortAI::UpdateAI(diff); + } +}; + +bool QuestAccept_npc_professor_phizzlethorpe(Player* player, Creature* creature, Quest const* quest) +{ + if (quest->GetQuestId() == QUEST_SUNKEN_TREASURE) + { + creature->Say(SAY_PROGRESS_1, LANG_UNIVERSAL, player->GetGUID()); + ((npc_escortAI*)(creature->AI()))->Start(false, false, false, player->GetGUID()); + } + return true; +} + +CreatureAI* GetAI_npc_professor_phizzlethorpeAI(Creature *_Creature) +{ + npc_professor_phizzlethorpeAI* professor_phizzlethorpeAI = new npc_professor_phizzlethorpeAI(_Creature); + + professor_phizzlethorpeAI->AddWaypoint(0, -2066.45, -2085.96, 9.08); + professor_phizzlethorpeAI->AddWaypoint(1, -2077.99, -2105.33, 13.24); + professor_phizzlethorpeAI->AddWaypoint(2, -2074.60, -2109.67, 14.24); + professor_phizzlethorpeAI->AddWaypoint(3, -2076.60, -2117.46, 16.67); + professor_phizzlethorpeAI->AddWaypoint(4, -2073.51, -2123.46, 18.42, 2000); + professor_phizzlethorpeAI->AddWaypoint(5, -2073.51, -2123.46, 18.42, 4000); + professor_phizzlethorpeAI->AddWaypoint(6, -2066.60, -2131.85, 21.56); + professor_phizzlethorpeAI->AddWaypoint(7, -2053.85, -2143.19, 20.31); + professor_phizzlethorpeAI->AddWaypoint(8, -2043.49, -2153.73, 20.20, 12000); + professor_phizzlethorpeAI->AddWaypoint(9, -2043.49, -2153.73, 20.20, 14000); + professor_phizzlethorpeAI->AddWaypoint(10, -2043.49, -2153.73, 20.20, 10000); + professor_phizzlethorpeAI->AddWaypoint(11, -2043.49, -2153.73, 20.20, 2000); + professor_phizzlethorpeAI->AddWaypoint(12, -2053.85, -2143.19, 20.31); + professor_phizzlethorpeAI->AddWaypoint(13, -2066.60, -2131.85, 21.56); + professor_phizzlethorpeAI->AddWaypoint(14, -2073.51, -2123.46, 18.42); + professor_phizzlethorpeAI->AddWaypoint(15, -2076.60, -2117.46, 16.67); + professor_phizzlethorpeAI->AddWaypoint(16, -2074.60, -2109.67, 14.24); + professor_phizzlethorpeAI->AddWaypoint(17, -2077.99, -2105.33, 13.24); + professor_phizzlethorpeAI->AddWaypoint(18, -2066.45, -2085.96, 9.08); + professor_phizzlethorpeAI->AddWaypoint(19, -2066.41, -2086.21, 8.97, 6000); + professor_phizzlethorpeAI->AddWaypoint(20, -2066.41, -2086.21, 8.97, 2000); + + return (CreatureAI*)professor_phizzlethorpeAI; +} + +void AddSC_arathi_highlands() +{ + Script * newscript; + + newscript = new Script; + newscript->Name = "npc_professor_phizzlethorpe"; + newscript->GetAI = &GetAI_npc_professor_phizzlethorpeAI; + newscript->pQuestAccept = &QuestAccept_npc_professor_phizzlethorpe; + newscript->RegisterSelf(); +}
\ No newline at end of file |