diff options
-rw-r--r-- | sql/updates/world/master/2025_05_27_05_world.sql | 7 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_dk.cpp | 30 |
2 files changed, 37 insertions, 0 deletions
diff --git a/sql/updates/world/master/2025_05_27_05_world.sql b/sql/updates/world/master/2025_05_27_05_world.sql new file mode 100644 index 00000000000..cdc4b9b7c6e --- /dev/null +++ b/sql/updates/world/master/2025_05_27_05_world.sql @@ -0,0 +1,7 @@ +DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_dk_crimson_scourge'; +INSERT INTO `spell_script_names` (`spell_id`,`ScriptName`) VALUES +(81136,'spell_dk_crimson_scourge'); + +DELETE FROM `spell_proc` WHERE `SpellId` IN (81141); +INSERT INTO `spell_proc` (`SpellId`,`SchoolMask`,`SpellFamilyName`,`SpellFamilyMask0`,`SpellFamilyMask1`,`SpellFamilyMask2`,`SpellFamilyMask3`,`ProcFlags`,`ProcFlags2`,`SpellTypeMask`,`SpellPhaseMask`,`HitMask`,`AttributesMask`,`DisableEffectsMask`,`ProcsPerMinute`,`Chance`,`Cooldown`,`Charges`) VALUES +(81141,0x00,15,0x00000000,0x00000000,0x00000000,0x00000000,0x0,0x4,0x0,0x0,0x0,0x8,0x0,0,100,0,1); -- Crimson Scourge diff --git a/src/server/scripts/Spells/spell_dk.cpp b/src/server/scripts/Spells/spell_dk.cpp index 7defc5a9398..9b309265233 100644 --- a/src/server/scripts/Spells/spell_dk.cpp +++ b/src/server/scripts/Spells/spell_dk.cpp @@ -54,8 +54,10 @@ enum DeathKnightSpells SPELL_DK_BRITTLE_DEBUFF = 374557, SPELL_DK_CLEAVING_STRIKES = 316916, SPELL_DK_CORPSE_EXPLOSION_TRIGGERED = 43999, + SPELL_DK_CRIMSON_SCOURGE_BUFF = 81141, SPELL_DK_DARK_SIMULACRUM_BUFF = 77616, SPELL_DK_DARK_SIMULACRUM_SPELLPOWER_BUFF = 94984, + SPELL_DK_DEATH_AND_DECAY = 43265, SPELL_DK_DEATH_AND_DECAY_DAMAGE = 52212, SPELL_DK_DEATH_AND_DECAY_INCREASE_TARGETS = 188290, SPELL_DK_DEATH_COIL_DAMAGE = 47632, @@ -359,6 +361,33 @@ class spell_dk_brittle : public AuraScript } }; +// 81136 - Crimson Scourge +class spell_dk_crimson_scourge : public AuraScript +{ + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo({ SPELL_DK_BLOOD_PLAGUE, SPELL_DK_CRIMSON_SCOURGE_BUFF, SPELL_DK_DEATH_AND_DECAY }); + } + + static bool CheckProc(AuraEffect const* /*aurEff*/, ProcEventInfo const& procInfo) + { + return procInfo.GetProcTarget()->HasAura(SPELL_DK_BLOOD_PLAGUE, procInfo.GetActor()->GetGUID()); + } + + static void HandleProc(AuraEffect const* /*aurEff*/, ProcEventInfo const& eventInfo) + { + Unit* actor = eventInfo.GetActor(); + actor->GetSpellHistory()->RestoreCharge(sSpellMgr->AssertSpellInfo(SPELL_DK_DEATH_AND_DECAY, DIFFICULTY_NONE)->ChargeCategoryId); + actor->CastSpell(actor, SPELL_DK_CRIMSON_SCOURGE_BUFF, TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR); + } + + void Register() override + { + DoCheckEffectProc += AuraCheckEffectProcFn(spell_dk_crimson_scourge::CheckProc, EFFECT_0, SPELL_AURA_DUMMY); + OnEffectProc += AuraEffectProcFn(spell_dk_crimson_scourge::HandleProc, EFFECT_0, SPELL_AURA_DUMMY); + } +}; + // 49028 - Dancing Rune Weapon /// 7.1.5 class spell_dk_dancing_rune_weapon : public AuraScript @@ -1420,6 +1449,7 @@ void AddSC_deathknight_spell_scripts() RegisterSpellScript(spell_dk_blooddrinker); RegisterSpellScript(spell_dk_blood_boil); RegisterSpellScript(spell_dk_brittle); + RegisterSpellScript(spell_dk_crimson_scourge); RegisterSpellScript(spell_dk_dancing_rune_weapon); RegisterSpellScript(spell_dk_dark_simulacrum); RegisterSpellScript(spell_dk_dark_simulacrum_buff); |