aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Spells/Spell.cpp
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2021-12-29 17:56:11 +0100
committerShauren <shauren.trinity@gmail.com>2021-12-29 17:56:11 +0100
commitb50783ae80bdd6595c8a5f262171fdef5659da2d (patch)
tree43bffdca888515c5e89a6f2bdccddc2a35a5b637 /src/server/game/Spells/Spell.cpp
parent115409f353141dc8cf49a91699e9593b1bf04385 (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.cpp10
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)
{