diff options
| author | ModoX <moardox@gmail.com> | 2021-10-11 14:50:04 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-10-11 14:50:04 +0200 |
| commit | 1673b6e2ff69b9a59522892280e91cc5085a5ec0 (patch) | |
| tree | 49b62131321c633ac6ed7ac9ea3f71d71d6211d8 /src/server/game/Spells/SpellEffects.cpp | |
| parent | d7302ffd1499433fef2cc4e824ae9443c3d2c79f (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.cpp | 22 |
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) |
