aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Spells/SpellEffects.cpp
diff options
context:
space:
mode:
authorModoX <moardox@gmail.com>2021-10-11 14:50:04 +0200
committerGitHub <noreply@github.com>2021-10-11 14:50:04 +0200
commit1673b6e2ff69b9a59522892280e91cc5085a5ec0 (patch)
tree49b62131321c633ac6ed7ac9ea3f71d71d6211d8 /src/server/game/Spells/SpellEffects.cpp
parentd7302ffd1499433fef2cc4e824ae9443c3d2c79f (diff)
Core/Spells: Implemented SPELL_EFFECT_CANCEL_CONVERSATION (#27037)
Diffstat (limited to 'src/server/game/Spells/SpellEffects.cpp')
-rw-r--r--src/server/game/Spells/SpellEffects.cpp22
1 files changed, 21 insertions, 1 deletions
diff --git a/src/server/game/Spells/SpellEffects.cpp b/src/server/game/Spells/SpellEffects.cpp
index c0e0af8045b..584508dc595 100644
--- a/src/server/game/Spells/SpellEffects.cpp
+++ b/src/server/game/Spells/SpellEffects.cpp
@@ -194,7 +194,7 @@ NonDefaultConstructible<SpellEffectHandlerFn> SpellEffectHandlers[TOTAL_SPELL_EF
&Spell::EffectDestroyAllTotems, //110 SPELL_EFFECT_DESTROY_ALL_TOTEMS
&Spell::EffectDurabilityDamage, //111 SPELL_EFFECT_DURABILITY_DAMAGE
&Spell::EffectNULL, //112 SPELL_EFFECT_112
- &Spell::EffectNULL, //113 SPELL_EFFECT_CANCEL_CONVERSATION
+ &Spell::EffectCancelConversation, //113 SPELL_EFFECT_CANCEL_CONVERSATION
&Spell::EffectTaunt, //114 SPELL_EFFECT_ATTACK_ME
&Spell::EffectDurabilityDamagePCT, //115 SPELL_EFFECT_DURABILITY_DAMAGE_PCT
&Spell::EffectSkinPlayerCorpse, //116 SPELL_EFFECT_SKIN_PLAYER_CORPSE one spell: Remove Insignia, bg usage, required special corpse flags...
@@ -5547,6 +5547,26 @@ void Spell::EffectCreateConversation()
Conversation::CreateConversation(effectInfo->MiscValue, unitCaster, destTarget->GetPosition(), ObjectGuid::Empty, GetSpellInfo());
}
+void Spell::EffectCancelConversation()
+{
+ if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)
+ return;
+
+ if (!unitTarget)
+ return;
+
+ std::vector<WorldObject*> objs;
+ Trinity::ObjectEntryAndPrivateOwnerIfExistsCheck check(unitTarget->GetGUID(), effectInfo->MiscValue);
+ Trinity::WorldObjectListSearcher<Trinity::ObjectEntryAndPrivateOwnerIfExistsCheck> checker(unitTarget, objs, check, GRID_MAP_TYPE_MASK_CONVERSATION);
+ Cell::VisitGridObjects(unitTarget, checker, 100.0f);
+
+ for (WorldObject* obj : objs)
+ {
+ if (Conversation* convo = obj->ToConversation())
+ convo->Remove();
+ }
+}
+
void Spell::EffectAddGarrisonFollower()
{
if (effectHandleMode != SPELL_EFFECT_HANDLE_HIT_TARGET)