diff options
author | Teleqraph <nyrdeveloper@gmail.com> | 2023-05-07 19:37:16 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-05-07 19:37:16 +0200 |
commit | 4fb5737e3dc55bfc79518ecb5ac37f41f937f270 (patch) | |
tree | 560a3110fcbe7833d814e58884003f69a31ad2f8 /src | |
parent | 6ef501b278774b16d5c57bf7a463731480155609 (diff) |
Scripts/Spells: Implement Painful Punishment (#28928)
Diffstat (limited to 'src')
-rw-r--r-- | src/server/scripts/Spells/spell_priest.cpp | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/server/scripts/Spells/spell_priest.cpp b/src/server/scripts/Spells/spell_priest.cpp index ee7a9c39814..bc2966279e0 100644 --- a/src/server/scripts/Spells/spell_priest.cpp +++ b/src/server/scripts/Spells/spell_priest.cpp @@ -102,6 +102,7 @@ enum PriestSpells SPELL_PRIEST_REVEL_IN_PURITY = 373003, SPELL_PRIEST_SHADOW_MEND_DAMAGE = 186439, SPELL_PRIEST_SHADOW_MEND_PERIODIC_DUMMY = 187464, + SPELL_PRIEST_SHADOW_WORD_PAIN = 589, SPELL_PRIEST_SHIELD_DISCIPLINE_ENERGIZE = 47755, SPELL_PRIEST_SHIELD_DISCIPLINE_PASSIVE = 197045, SPELL_PRIEST_SINS_OF_THE_MANY = 280398, @@ -757,6 +758,42 @@ class spell_pri_mind_bomb : public AuraScript } }; +// 390686 - Painful Punishment +class spell_pri_painful_punishment : public AuraScript +{ + PrepareAuraScript(spell_pri_painful_punishment); + + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo + ({ + SPELL_PRIEST_SHADOW_WORD_PAIN, + SPELL_PRIEST_PURGE_THE_WICKED_PERIODIC + }); + } + + void HandleEffectProc(AuraEffect* aurEff, ProcEventInfo& eventInfo) + { + Unit* caster = eventInfo.GetActor(); + Unit* target = eventInfo.GetActionTarget(); + if (!caster || !target) + return; + + int32 additionalDuration = aurEff->GetAmount(); + + if (Aura* shadowWordPain = target->GetOwnedAura(SPELL_PRIEST_SHADOW_WORD_PAIN, caster->GetGUID())) + shadowWordPain->SetDuration(shadowWordPain->GetDuration() + additionalDuration); + + if (Aura* purgeTheWicked = target->GetOwnedAura(SPELL_PRIEST_PURGE_THE_WICKED_PERIODIC, caster->GetGUID())) + purgeTheWicked->SetDuration(purgeTheWicked->GetDuration() + additionalDuration); + } + + void Register() override + { + OnEffectProc += AuraEffectProcFn(spell_pri_painful_punishment::HandleEffectProc, EFFECT_0, SPELL_AURA_DUMMY); + } +}; + // 47540 - Penance // 400169 - Dark Reprimand class spell_pri_penance : public SpellScript @@ -1802,6 +1839,7 @@ void AddSC_priest_spell_scripts() RegisterSpellScript(spell_pri_leap_of_faith_effect_trigger); RegisterSpellScript(spell_pri_levitate); RegisterSpellScript(spell_pri_mind_bomb); + RegisterSpellScript(spell_pri_painful_punishment); RegisterSpellScriptWithArgs(spell_pri_penance, "spell_pri_penance", SPELL_PRIEST_PENANCE_CHANNEL_DAMAGE, SPELL_PRIEST_PENANCE_CHANNEL_HEALING); RegisterSpellScriptWithArgs(spell_pri_penance, "spell_pri_dark_reprimand", SPELL_PRIEST_DARK_REPRIMAND_CHANNEL_DAMAGE, SPELL_PRIEST_DARK_REPRIMAND_CHANNEL_HEALING); RegisterSpellScript(spell_pri_penance_or_dark_reprimand_channeled); |