aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorKeader <keader.android@gmail.com>2020-10-12 19:56:56 -0300
committerShauren <shauren.trinity@gmail.com>2022-02-28 21:36:21 +0100
commitab189bfc42d8b8fc61dbf0330f07550df99819f8 (patch)
treef5c95d4638964d2aa4713ae83a0d441961df4aa8 /src
parent503ac5556d3b5e52340bee9d27811645ebf96c7a (diff)
Scripts/ICC: Fixed Chocking Gas killing Abomination (#25565)
(cherry picked from commit 3c0766df545f4c2d2d045272f37087deccea458d)
Diffstat (limited to 'src')
-rw-r--r--src/server/scripts/Northrend/IcecrownCitadel/boss_professor_putricide.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/src/server/scripts/Northrend/IcecrownCitadel/boss_professor_putricide.cpp b/src/server/scripts/Northrend/IcecrownCitadel/boss_professor_putricide.cpp
index b9f7575406e..861ab65de60 100644
--- a/src/server/scripts/Northrend/IcecrownCitadel/boss_professor_putricide.cpp
+++ b/src/server/scripts/Northrend/IcecrownCitadel/boss_professor_putricide.cpp
@@ -1450,6 +1450,39 @@ class spell_abomination_mutated_transformation : public SpellScript
}
};
+// 71278, 72460, 72619, 72620 - Choking Gas
+// 71279, 72459, 72621, 72622 - Choking Gas Explosion
+class spell_putricide_choking_gas_filter : public SpellScript
+{
+ PrepareSpellScript(spell_putricide_choking_gas_filter);
+
+ bool Validate(SpellInfo const* /*spell*/) override
+ {
+ return ValidateSpellInfo({ SPELL_OOZE_VARIABLE, SPELL_GAS_VARIABLE });
+ }
+
+ void FilterTargets(std::list<WorldObject*>& targets)
+ {
+ targets.remove_if([](WorldObject* obj)
+ {
+ return obj->ToUnit() && obj->ToUnit()->GetVehicle();
+ });
+ }
+
+ void HandleDispel(SpellEffIndex /*effIndex*/)
+ {
+ Unit* target = GetHitUnit();
+ target->RemoveAurasDueToSpell(SPELL_OOZE_VARIABLE);
+ target->RemoveAurasDueToSpell(SPELL_GAS_VARIABLE);
+ }
+
+ void Register() override
+ {
+ OnObjectAreaTargetSelect += SpellObjectAreaTargetSelectFn(spell_putricide_choking_gas_filter::FilterTargets, EFFECT_ALL, TARGET_UNIT_SRC_AREA_ENTRY);
+ OnEffectHitTarget += SpellEffectFn(spell_putricide_choking_gas_filter::HandleDispel, EFFECT_1, SPELL_EFFECT_APPLY_AURA);
+ }
+};
+
void AddSC_boss_professor_putricide()
{
// Creatures
@@ -1477,4 +1510,5 @@ void AddSC_boss_professor_putricide()
RegisterSpellScript(spell_putricide_clear_aura_effect_value);
RegisterSpellScript(spell_stinky_precious_decimate);
RegisterSpellScript(spell_abomination_mutated_transformation);
+ RegisterSpellScript(spell_putricide_choking_gas_filter);
}