aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sql/updates/world/master/2018_03_17_26_world_2016_12_27_10_world.sql3
-rw-r--r--src/server/scripts/Kalimdor/TempleOfAhnQiraj/boss_skeram.cpp44
2 files changed, 43 insertions, 4 deletions
diff --git a/sql/updates/world/master/2018_03_17_26_world_2016_12_27_10_world.sql b/sql/updates/world/master/2018_03_17_26_world_2016_12_27_10_world.sql
new file mode 100644
index 00000000000..714724a3962
--- /dev/null
+++ b/sql/updates/world/master/2018_03_17_26_world_2016_12_27_10_world.sql
@@ -0,0 +1,3 @@
+DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_skeram_true_fulfillment';
+INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES
+(785,'spell_skeram_true_fulfillment');
diff --git a/src/server/scripts/Kalimdor/TempleOfAhnQiraj/boss_skeram.cpp b/src/server/scripts/Kalimdor/TempleOfAhnQiraj/boss_skeram.cpp
index 40ef4af53f6..e00f4847da5 100644
--- a/src/server/scripts/Kalimdor/TempleOfAhnQiraj/boss_skeram.cpp
+++ b/src/server/scripts/Kalimdor/TempleOfAhnQiraj/boss_skeram.cpp
@@ -34,8 +34,10 @@ enum Spells
SPELL_ARCANE_EXPLOSION = 26192,
SPELL_EARTH_SHOCK = 26194,
SPELL_TRUE_FULFILLMENT = 785,
+ SPELL_TRUE_FULFILLMENT_2 = 2313,
SPELL_INITIALIZE_IMAGE = 3730,
- SPELL_SUMMON_IMAGES = 747
+ SPELL_SUMMON_IMAGES = 747,
+ SPELL_GENERIC_DISMOUNT = 61286
};
enum Events
@@ -158,9 +160,8 @@ class boss_skeram : public CreatureScript
events.ScheduleEvent(EVENT_ARCANE_EXPLOSION, urand(8000, 18000));
break;
case EVENT_FULLFILMENT:
- /// @todo For some weird reason boss does not cast this
- // Spell actually works, tested in duel
- DoCast(SelectTarget(SELECT_TARGET_RANDOM, 0, 0.0f, true), SPELL_TRUE_FULFILLMENT, true);
+ if (Unit* target = SelectTarget(SELECT_TARGET_RANDOM, 1, 45.0f, true))
+ DoCast(target, SPELL_TRUE_FULFILLMENT);
events.ScheduleEvent(EVENT_FULLFILMENT, urand(20000, 30000));
break;
case EVENT_BLINK:
@@ -203,6 +204,7 @@ class boss_skeram : public CreatureScript
}
};
+// 26192 - Arcane Explosion
class spell_skeram_arcane_explosion : public SpellScriptLoader
{
public:
@@ -232,8 +234,42 @@ class spell_skeram_arcane_explosion : public SpellScriptLoader
}
};
+// 785 - True Fulfillment
+class spell_skeram_true_fulfillment : public SpellScriptLoader
+{
+public:
+ spell_skeram_true_fulfillment() : SpellScriptLoader("spell_skeram_true_fulfillment") { }
+
+ class spell_skeram_true_fulfillment_SpellScript : public SpellScript
+ {
+ PrepareSpellScript(spell_skeram_true_fulfillment_SpellScript);
+
+ bool Validate(SpellInfo const* /*spellInfo*/) override
+ {
+ return ValidateSpellInfo({ SPELL_GENERIC_DISMOUNT, SPELL_TRUE_FULFILLMENT_2 });
+ }
+
+ void HandleEffect(SpellEffIndex /*effIndex*/)
+ {
+ GetCaster()->CastSpell(GetHitUnit(), SPELL_GENERIC_DISMOUNT, true);
+ GetCaster()->CastSpell(GetHitUnit(), SPELL_TRUE_FULFILLMENT_2, true);
+ }
+
+ void Register() override
+ {
+ OnEffectHitTarget += SpellEffectFn(spell_skeram_true_fulfillment_SpellScript::HandleEffect, EFFECT_0, SPELL_AURA_MOD_CHARM);
+ }
+ };
+
+ SpellScript* GetSpellScript() const override
+ {
+ return new spell_skeram_true_fulfillment_SpellScript();
+ }
+};
+
void AddSC_boss_skeram()
{
new boss_skeram();
new spell_skeram_arcane_explosion();
+ new spell_skeram_true_fulfillment();
}