diff options
| author | Shauren <shauren.trinity@gmail.com> | 2021-12-29 17:56:11 +0100 |
|---|---|---|
| committer | Shauren <shauren.trinity@gmail.com> | 2021-12-29 17:56:11 +0100 |
| commit | b50783ae80bdd6595c8a5f262171fdef5659da2d (patch) | |
| tree | 43bffdca888515c5e89a6f2bdccddc2a35a5b637 /src/server/game/Spells/Spell.cpp | |
| parent | 115409f353141dc8cf49a91699e9593b1bf04385 (diff) | |
Core/Spells: Implemented target 115 TARGET_UNIT_SRC_AREA_FURTHEST_ENEMY
Diffstat (limited to 'src/server/game/Spells/Spell.cpp')
| -rw-r--r-- | src/server/game/Spells/Spell.cpp | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp index 7b057e6b28b..10f2bda5cde 100644 --- a/src/server/game/Spells/Spell.cpp +++ b/src/server/game/Spells/Spell.cpp @@ -1288,11 +1288,19 @@ void Spell::SelectImplicitAreaTargets(SpellEffectInfo const& spellEffectInfo, Sp CallScriptObjectAreaTargetSelectHandlers(targets, spellEffectInfo.EffectIndex, targetType); + if (targetType.GetTarget() == TARGET_UNIT_SRC_AREA_FURTHEST_ENEMY) + targets.sort(Trinity::ObjectDistanceOrderPred(referer, false)); + if (!targets.empty()) { // Other special target selection goes here if (uint32 maxTargets = m_spellValue->MaxAffectedTargets) - Trinity::Containers::RandomResize(targets, maxTargets); + { + if (targetType.GetTarget() != TARGET_UNIT_SRC_AREA_FURTHEST_ENEMY) + Trinity::Containers::RandomResize(targets, maxTargets); + else if (targets.size() > maxTargets) + targets.resize(maxTargets); + } for (std::list<WorldObject*>::iterator itr = targets.begin(); itr != targets.end(); ++itr) { |
