From f6e357902fa9026502740e0998eb4bfc678c2deb Mon Sep 17 00:00:00 2001 From: kaelima Date: Fri, 13 May 2011 01:19:54 +0200 Subject: Revert part of 82dcb31eeec24b4be242 --- .../scripts/Outland/boss_doomlord_kazzak.cpp | 49 +--------------------- 1 file changed, 2 insertions(+), 47 deletions(-) (limited to 'src/server/scripts') diff --git a/src/server/scripts/Outland/boss_doomlord_kazzak.cpp b/src/server/scripts/Outland/boss_doomlord_kazzak.cpp index 87dec120e90..ce82cc2e6ed 100644 --- a/src/server/scripts/Outland/boss_doomlord_kazzak.cpp +++ b/src/server/scripts/Outland/boss_doomlord_kazzak.cpp @@ -134,17 +134,8 @@ class boss_doomlord_kazzak : public CreatureScript _events.ScheduleEvent(EVENT_VOIDBOLT, urand(15000, 18000)); break; case EVENT_MARK_OF_KAZZAK: - std::list targetList; - { - const std::list& threatlist = me->getThreatManager().getThreatList(); - for (std::list::const_iterator itr = threatlist.begin(); itr != threatlist.end(); ++itr) - if ((*itr)->getTarget()->GetTypeId() == TYPEID_PLAYER && (*itr)->getTarget()->getPowerType() == POWER_MANA) - targetList.push_back((*itr)->getTarget()); - } - - std::list::iterator itr = targetList.begin(); - advance(itr, urand(0, targetList.size()-1)); - DoCast(*itr, SPELL_MARKOFKAZZAK); + if (Unit* target = SelectTarget(SELECT_TARGET_RANDOM, 0, 0.0f, true)) + DoCast(target, SPELL_MARKOFKAZZAK); _events.ScheduleEvent(EVENT_MARK_OF_KAZZAK, 20000); break; case EVENT_ENRAGE: @@ -175,43 +166,7 @@ class boss_doomlord_kazzak : public CreatureScript } }; -class spell_doomlord_kazzak_mark_of_kazzak : public SpellScriptLoader -{ - public: - spell_doomlord_kazzak_mark_of_kazzak() : SpellScriptLoader("spell_doomlord_kazzak_mark_of_kazzak") { } - - class spell_doomlord_kazzak_mark_of_kazzak_AuraScript : public AuraScript - { - PrepareAuraScript(spell_doomlord_kazzak_mark_of_kazzak_AuraScript); - - void HandlePeriodicTick(AuraEffect const* /*aurEff*/) - { - PreventDefaultAction(); - - int32 curmana = GetHitUnit()->GetPower(POWER_MANA); - int32 maxmana = GetHitUnit()->GetMaxPower(POWER_MANA); - - // If mana is above 5 procent, drain. Otherwise cast 32961 (player on self with Doomlord Kazzak as casterguid) - if (curmana * 100 > maxmana * 5) - GetHitUnit()->ModifyPower(POWER_MANA, -5); - else - GetHitUnit()->CastSpell(GetHitUnit(), SPELL_MARKOFKAZZAK_DAMAGE, true, NULL, NULL, GetCasterGUID()); - } - - void Register() - { - OnEffectPeriodic += AuraEffectPeriodicFn(spell_doomlord_kazzak_mark_of_kazzak_AuraScript::HandlePeriodicTick, EFFECT_0, SPELL_AURA_PERIODIC_MANA_LEECH); - } - }; - - AuraScript* GetAuraScript() const - { - return new spell_doomlord_kazzak_mark_of_kazzak_AuraScript(); - } -}; - void AddSC_boss_doomlordkazzak() { new boss_doomlord_kazzak(); - new spell_doomlord_kazzak_mark_of_kazzak(); } -- cgit v1.2.3