Skip to content

Commit bfb06b7

Browse files
authored
Scripts/Spells: Implement priest talent Angelic Bulwark (TrinityCore#31450)
1 parent ccdfd71 commit bfb06b7

File tree

2 files changed

+44
-0
lines changed

2 files changed

+44
-0
lines changed
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
DELETE FROM `spell_script_names` WHERE `ScriptName` IN ('spell_pri_angelic_bulwark');
2+
INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES
3+
(108945, 'spell_pri_angelic_bulwark');

src/server/scripts/Spells/spell_priest.cpp

Lines changed: 41 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -43,6 +43,8 @@
4343
enum PriestSpells
4444
{
4545
SPELL_PRIEST_ABYSSAL_REVERIE = 373054,
46+
SPELL_PRIEST_ANGELIC_BULWARK_BUFF = 114214,
47+
SPELL_PRIEST_ANGELIC_BULWARK_DEBUFF = 114216,
4648
SPELL_PRIEST_ANGELIC_FEATHER_AREATRIGGER = 158624,
4749
SPELL_PRIEST_ANGELIC_FEATHER_AURA = 121557,
4850
SPELL_PRIEST_ANSWERED_PRAYERS = 394289,
@@ -249,6 +251,44 @@ class RaidCheck
249251
Unit const* _caster;
250252
};
251253

254+
// 108945 - Angelic Bulwark
255+
class spell_pri_angelic_bulwark : public AuraScript
256+
{
257+
bool Validate(SpellInfo const* spellInfo) override
258+
{
259+
return ValidateSpellInfo({ SPELL_PRIEST_ANGELIC_BULWARK_BUFF, SPELL_PRIEST_ANGELIC_BULWARK_DEBUFF })
260+
&& ValidateSpellEffect({ { spellInfo->Id, EFFECT_1 } });
261+
}
262+
263+
bool CheckProc(ProcEventInfo const& eventInfo) const
264+
{
265+
return eventInfo.GetDamageInfo() && !eventInfo.GetActionTarget()->HasAura(SPELL_PRIEST_ANGELIC_BULWARK_DEBUFF)
266+
&& eventInfo.GetActionTarget()->HealthBelowPctDamaged(GetEffect(EFFECT_0)->GetAmount(), eventInfo.GetDamageInfo()->GetDamage());
267+
}
268+
269+
void HandleProc(ProcEventInfo const& eventInfo) const
270+
{
271+
Unit* caster = eventInfo.GetActionTarget();
272+
if (!caster)
273+
return;
274+
275+
int32 absorb = caster->CountPctFromMaxHealth(GetEffect(EFFECT_1)->GetAmount());
276+
277+
caster->CastSpell(caster, SPELL_PRIEST_ANGELIC_BULWARK_BUFF, CastSpellExtraArgsInit
278+
{
279+
.TriggerFlags = TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR,
280+
.SpellValueOverrides = { { SPELLVALUE_BASE_POINT0, absorb } }
281+
});
282+
caster->CastSpell(caster, SPELL_PRIEST_ANGELIC_BULWARK_DEBUFF, TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR);
283+
}
284+
285+
void Register() override
286+
{
287+
DoCheckProc += AuraCheckProcFn(spell_pri_angelic_bulwark::CheckProc);
288+
OnProc += AuraProcFn(spell_pri_angelic_bulwark::HandleProc);
289+
}
290+
};
291+
252292
// 121536 - Angelic Feather talent
253293
class spell_pri_angelic_feather_trigger : public SpellScript
254294
{
@@ -3959,6 +3999,7 @@ class spell_pri_whispering_shadows_effect : public SpellScript
39593999

39604000
void AddSC_priest_spell_scripts()
39614001
{
4002+
RegisterSpellScript(spell_pri_angelic_bulwark);
39624003
RegisterSpellScript(spell_pri_angelic_feather_trigger);
39634004
RegisterAreaTriggerAI(areatrigger_pri_angelic_feather);
39644005
RegisterSpellScript(spell_pri_abyssal_reverie);

0 commit comments

Comments
 (0)