aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sql/scripts/world_script_texts.sql12
-rw-r--r--sql/updates/world/2011_05_12_09_world_creature_text.sql14
-rw-r--r--src/server/scripts/Outland/boss_doomlord_kazzak.cpp250
3 files changed, 140 insertions, 136 deletions
diff --git a/sql/scripts/world_script_texts.sql b/sql/scripts/world_script_texts.sql
index 341fcc1960a..1f4115039eb 100644
--- a/sql/scripts/world_script_texts.sql
+++ b/sql/scripts/world_script_texts.sql
@@ -91,18 +91,6 @@ INSERT INTO `script_texts` (`npc_entry`,`entry`,`content_default`,`content_loc1`
(16295,-1000144,'Thank you for saving my life and bringing me back to safety, $N',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,0,'lilatha SAY_END1'),
(16295,-1000145,'Captain Helios, I''ve been rescued from the Amani Catacombs. Reporting for duty, sir!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,0,'lilatha SAY_END2'),
(16295,-1000146,'Liatha, get someone to look at those injuries. Thank you for bringing her back safely.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,0,1,0,'lilatha CAPTAIN_ANSWER'),
- (10427,-1000147,'I remember well the sting of defeat at the conclusion of the Third War. I have waited far too long for my revenge. Now the shadow of the Legion falls over this world. It is only a matter of time until all of your failed creation... is undone.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11332,1,0,0,'kazzak SAY_INTRO'),
- (10427,-1000148,'The Legion will conquer all!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11333,1,0,0,'kazzak SAY_AGGRO1'),
- (10427,-1000149,'All mortals will perish!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11334,1,0,0,'kazzak SAY_AGGRO2'),
- (20129,-1000150,'All life must be eradicated!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11335,1,0,0,'kazzak SAY_SURPREME1'),
- (20129,-1000151,'I''ll rip the flesh from your bones!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11336,1,0,0,'kazzak SAY_SURPREME2'),
- (20129,-1000152,'Kirel Narak!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11337,1,0,0,'kazzak SAY_KILL1'),
- (20129,-1000153,'Contemptible wretch!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11338,1,0,0,'kazzak SAY_KILL2'),
- (20129,-1000154,'The universe will be remade.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11339,1,0,0,'kazzak SAY_KILL3'),
- (20129,-1000155,'The Legion... will never... fall.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11340,1,0,0,'kazzak SAY_DEATH'),
- (20129,-1000156,'%s goes into a frenzy!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,2,0,0,'kazzak EMOTE_FRENZY'),
- (20129,-1000157,'Invaders, you dangle upon the precipice of oblivion! The Burning Legion comes and with it comes your end.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,1,0,0,'kazzak SAY_RAND1'),
- (20129,-1000158,'Impudent whelps, you only delay the inevitable. Where one has fallen, ten shall rise. Such is the will of Kazzak...',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,0,1,0,0,'kazzak SAY_RAND2'),
(20129,-1000159,'Do not proceed. You will be eliminated!',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11344,1,0,0,'doomwalker SAY_AGGRO'),
(20129,-1000160,'Tectonic disruption commencing.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11345,1,0,0,'doomwalker SAY_EARTHQUAKE_1'),
(20129,-1000161,'Magnitude set. Release.',NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,11346,1,0,0,'doomwalker SAY_EARTHQUAKE_2'),
diff --git a/sql/updates/world/2011_05_12_09_world_creature_text.sql b/sql/updates/world/2011_05_12_09_world_creature_text.sql
new file mode 100644
index 00000000000..f63c3ed3e63
--- /dev/null
+++ b/sql/updates/world/2011_05_12_09_world_creature_text.sql
@@ -0,0 +1,14 @@
+DELETE FROM `creature_text` WHERE `entry` IN (18728);
+INSERT INTO `creature_text` (`entry`,`groupid`,`id`,`text`,`type`,`sound`,`language`,`probability`,`emote`,`duration`,`comment`) VALUES
+(18728,0,0,'I remember well the sting of defeat at the conclusion of the Third War. I have waited far too long for my revenge. Now the shadow of the Legion falls over this world. It is only a matter of time until all of your failed creation... is undone.',1,11332,'kazzak SAY_INTRO'),
+(18728,1,0,'The Legion will conquer all!',1,11333,'kazzak SAY_AGGRO1'),
+(18728,1,1,'All mortals will perish!',1,11334,'kazzak SAY_AGGRO2'),
+(18728,2,0,'All life must be eradicated!',1,11335,'kazzak SAY_SURPREME1'),
+(18728,2,1,'I''ll rip the flesh from your bones!',1,11336,'kazzak SAY_SURPREME2'),
+(18728,3,0,'Kirel Narak!',1,11337,'kazzak SAY_KILL1'),
+(18728,3,1,'Contemptible wretch!',1,11338,'kazzak SAY_KILL2'),
+(18728,3,2,'The universe will be remade.',1,11339,'kazzak SAY_KILL3'),
+(18728,4,0,'The Legion... will never... fall.',1,11340,'kazzak SAY_DEATH'),
+(18728,5,0,'%s goes into a frenzy!',2,0,'kazzak EMOTE_FRENZY'),
+(18728,6,0,'Invaders, you dangle upon the precipice of oblivion! The Burning Legion comes and with it comes your end.',1,0,'kazzak SAY_RAND1'),
+(18728,6,1,'Impudent whelps, you only delay the inevitable. Where one has fallen, ten shall rise. Such is the will of Kazzak...',1,0,'kazzak SAY_RAND2');
diff --git a/src/server/scripts/Outland/boss_doomlord_kazzak.cpp b/src/server/scripts/Outland/boss_doomlord_kazzak.cpp
index d04a4b7b205..20512a448b6 100644
--- a/src/server/scripts/Outland/boss_doomlord_kazzak.cpp
+++ b/src/server/scripts/Outland/boss_doomlord_kazzak.cpp
@@ -25,151 +25,153 @@ EndScriptData */
#include "ScriptPCH.h"
-#define SAY_INTRO -1000147
-#define SAY_AGGRO1 -1000148
-#define SAY_AGGRO2 -1000149
-#define SAY_SURPREME1 -1000154
-#define SAY_SURPREME2 -1000149
-#define SAY_KILL1 -1000150
-#define SAY_KILL2 -1000151
-#define SAY_KILL3 -1000152
-#define SAY_DEATH -1000155
-#define EMOTE_FRENZY -1000151
-#define SAY_RAND1 -1000158
-#define SAY_RAND2 -1000157
-
-#define SPELL_SHADOWVOLLEY 32963
-#define SPELL_CLEAVE 31779
-#define SPELL_THUNDERCLAP 36706
-#define SPELL_VOIDBOLT 39329
-#define SPELL_MARKOFKAZZAK 32960
-#define SPELL_ENRAGE 32964
-#define SPELL_CAPTURESOUL 32966
-#define SPELL_TWISTEDREFLECTION 21063
-
-class boss_doomlord_kazzak : public CreatureScript
+enum Yells
{
-public:
- boss_doomlord_kazzak() : CreatureScript("boss_doomlord_kazzak") { }
-
- CreatureAI* GetAI(Creature* pCreature) const
- {
- return new boss_doomlordkazzakAI (pCreature);
- }
-
- struct boss_doomlordkazzakAI : public ScriptedAI
- {
- boss_doomlordkazzakAI(Creature *c) : ScriptedAI(c) {}
-
- uint32 ShadowVolley_Timer;
- uint32 Cleave_Timer;
- uint32 ThunderClap_Timer;
- uint32 VoidBolt_Timer;
- uint32 MarkOfKazzak_Timer;
- uint32 Enrage_Timer;
- uint32 Twisted_Reflection_Timer;
-
- void Reset()
- {
- ShadowVolley_Timer = 6000 + rand()%4000;
- Cleave_Timer = 7000;
- ThunderClap_Timer = 14000 + rand()%4000;
- VoidBolt_Timer = 30000;
- MarkOfKazzak_Timer = 25000;
- Enrage_Timer = 60000;
- Twisted_Reflection_Timer = 33000; // Timer may be incorrect
- }
-
- void JustRespawned()
- {
- DoScriptText(SAY_INTRO, me);
- }
-
- void EnterCombat(Unit * /*who*/)
- {
- DoScriptText(RAND(SAY_AGGRO1, SAY_AGGRO2), me);
- }
-
- void KilledUnit(Unit* victim)
- {
- // When Kazzak kills a player (not pets/totems), he regens some health
- if (victim->GetTypeId() != TYPEID_PLAYER)
- return;
+ SAY_INTRO = 0,
+ SAY_AGGRO = 1,
+ SAY_SURPREME = 2,
+ SAY_KILL = 3,
+ SAY_DEATH = 4,
+ EMOTE_FRENZY = 5,
+ SAY_RAND = 6
+};
- DoCast(me, SPELL_CAPTURESOUL);
+enum Spells
+{
+ SPELL_SHADOWVOLLEY = 32963,
+ SPELL_CLEAVE = 31779,
+ SPELL_THUNDERCLAP = 36706,
+ SPELL_VOIDBOLT = 39329,
+ SPELL_MARKOFKAZZAK = 32960,
+ SPELL_ENRAGE = 32964,
+ SPELL_CAPTURESOUL = 32966,
+ SPELL_TWISTEDREFLECTION = 21063
+};
- DoScriptText(RAND(SAY_KILL1, SAY_KILL2, SAY_KILL3), me);
- }
+enum Events
+{
+ EVENT_SHADOW_VOLLEY = 1,
+ EVENT_CLEAVE = 2,
+ EVENT_THUNDERCLAP = 3,
+ EVENT_VOIDBOLT = 4,
+ EVENT_MARK_OF_KAZZAK = 5,
+ EVENT_ENRAGE = 6,
+ EVENT_TWISTED_REFLECTION = 7
+};
- void JustDied(Unit * /*victim*/)
- {
- DoScriptText(SAY_DEATH, me);
- }
+class boss_doomlord_kazzak : public CreatureScript
+{
+ public:
+ boss_doomlord_kazzak() : CreatureScript("boss_doomlord_kazzak") { }
- void UpdateAI(const uint32 diff)
+ struct boss_doomlordkazzakAI : public ScriptedAI
{
- //Return since we have no target
- if (!UpdateVictim())
- return;
+ boss_doomlordkazzakAI(Creature* creature) : ScriptedAI(creature)
+ {
+ }
- //ShadowVolley_Timer
- if (ShadowVolley_Timer <= diff)
+ void Reset()
{
- DoCast(me->getVictim(), SPELL_SHADOWVOLLEY);
- ShadowVolley_Timer = 4000 + rand()%2000;
- } else ShadowVolley_Timer -= diff;
+ events.Reset();
+ events.ScheduleEvent(EVENT_SHADOW_VOLLEY, urand(6000, 10000));
+ events.ScheduleEvent(EVENT_CLEAVE, 7000);
+ events.ScheduleEvent(EVENT_THUNDERCLAP, urand(14000, 18000));
+ events.ScheduleEvent(EVENT_VOIDBOLT, 30000);
+ events.ScheduleEvent(EVENT_MARK_OF_KAZZAK, 25000);
+ events.ScheduleEvent(EVENT_ENRAGE, 60000);
+ events.ScheduleEvent(EVENT_TWISTED_REFLECTION, 33000);
+ }
+
+ void JustRespawned()
+ {
+ Talk(SAY_INTRO);
+ }
- //Cleave_Timer
- if (Cleave_Timer <= diff)
+ void EnterCombat(Unit * /*who*/)
{
- DoCast(me->getVictim(), SPELL_CLEAVE);
- Cleave_Timer = 8000 + rand()%4000;
- } else Cleave_Timer -= diff;
+ Talk(SAY_AGGRO);
+ }
- //ThunderClap_Timer
- if (ThunderClap_Timer <= diff)
+ void KilledUnit(Unit* victim)
{
- DoCast(me->getVictim(), SPELL_THUNDERCLAP);
- ThunderClap_Timer = 10000 + rand()%4000;
- } else ThunderClap_Timer -= diff;
+ // When Kazzak kills a player (not pets/totems), he regens some health
+ if (victim->GetTypeId() != TYPEID_PLAYER)
+ return;
- //VoidBolt_Timer
- if (VoidBolt_Timer <= diff)
+ DoCast(me, SPELL_CAPTURESOUL);
+
+ Talk(SAY_KILL);
+ }
+
+ void JustDied(Unit * /*victim*/)
{
- DoCast(me->getVictim(), SPELL_VOIDBOLT);
- VoidBolt_Timer = 15000 + rand()%3000;
- } else VoidBolt_Timer -= diff;
+ Talk(SAY_DEATH);
+ }
- //MarkOfKazzak_Timer
- if (MarkOfKazzak_Timer <= diff)
+ void UpdateAI(const uint32 diff)
{
- Unit* victim = SelectTarget(SELECT_TARGET_RANDOM, 0);
- if (victim->GetPower(POWER_MANA))
+ //Return since we have no target
+ if (!UpdateVictim())
+ return;
+
+ events.Update(diff);
+
+ if (me->HasUnitState(UNIT_STAT_CASTING))
+ return;
+
+ while (uint32 eventId = events.ExecuteEvent())
{
- DoCast(victim, SPELL_MARKOFKAZZAK);
- MarkOfKazzak_Timer = 20000;
+ switch(eventId)
+ {
+ case EVENT_SHADOW_VOLLEY:
+ DoCastVictim(SPELL_SHADOWVOLLEY);
+ events.ScheduleEvent(EVENT_SHADOW_VOLLEY, urand(4000, 6000));
+ break;
+ case EVENT_CLEAVE:
+ DoCastVictim(SPELL_CLEAVE);
+ events.ScheduleEvent(EVENT_CLEAVE, urand(8000, 12000));
+ break;
+ case EVENT_THUNDERCLAP:
+ DoCastVictim(SPELL_THUNDERCLAP);
+ events.ScheduleEvent(EVENT_THUNDERCLAP, urand(10000, 14000));
+ break;
+ case EVENT_VOIDBOLT:
+ DoCastVictim(SPELL_VOIDBOLT);
+ events.ScheduleEvent(EVENT_VOIDBOLT, urand(15000, 18000));
+ break;
+ case EVENT_MARK_OF_KAZZAK:
+ if (Unit* target = SelectTarget(SELECT_TARGET_RANDOM, 0))
+ if (target->GetPower(POWER_MANA))
+ DoCast(target, SPELL_MARKOFKAZZAK);
+ events.ScheduleEvent(EVENT_MARK_OF_KAZZAK, 20000);
+ break;
+ case EVENT_ENRAGE:
+ Talk(EMOTE_FRENZY);
+ DoCast(me, SPELL_ENRAGE);
+ events.ScheduleEvent(EVENT_ENRAGE, 30000);
+ break;
+ case EVENT_TWISTED_REFLECTION:
+ if (Unit* target = SelectTarget(SELECT_TARGET_RANDOM, 0))
+ DoCast(target, SPELL_TWISTEDREFLECTION);
+ events.ScheduleEvent(EVENT_TWISTED_REFLECTION, 15000);
+ break;
+ default:
+ break;
+ }
}
- } else MarkOfKazzak_Timer -= diff;
-
- //Enrage_Timer
- if (Enrage_Timer <= diff)
- {
- DoScriptText(EMOTE_FRENZY, me);
- DoCast(me, SPELL_ENRAGE);
- Enrage_Timer = 30000;
- } else Enrage_Timer -= diff;
+
+ DoMeleeAttackIfReady();
+ }
- if (Twisted_Reflection_Timer <= diff)
- {
- DoCast(SelectTarget(SELECT_TARGET_RANDOM, 0), SPELL_TWISTEDREFLECTION);
- Twisted_Reflection_Timer = 15000;
- } else Twisted_Reflection_Timer -= diff;
+ private:
+ EventMap events;
- DoMeleeAttackIfReady();
+ };
+
+ CreatureAI *GetAI(Creature* creature) const
+ {
+ return new boss_doomlordkazzakAI (creature);
}
-
- };
-
};
void AddSC_boss_doomlordkazzak()