aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAqua Deus <95978183+aquadeus@users.noreply.github.com>2025-05-27 21:17:22 +0200
committerGitHub <noreply@github.com>2025-05-27 21:17:22 +0200
commit675f9da415a59c5753814b6c39bd9124cd11ad5e (patch)
tree55a61536ebff8206796cad23dff960f5d2b290d2
parent2d717e1818a4cde456abe39ef5196be8e7c60687 (diff)
Scripts/Spells: Implement death knight talent Crimson Scourge (#30966)
-rw-r--r--sql/updates/world/master/2025_05_27_05_world.sql7
-rw-r--r--src/server/scripts/Spells/spell_dk.cpp30
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);