aboutsummaryrefslogtreecommitdiff
path: root/src/server/game/Spells/Spell.cpp
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2024-07-03 16:18:06 +0200
committerShauren <shauren.trinity@gmail.com>2024-07-03 16:18:06 +0200
commitf19e1a271618a35515512ce2a64330f21133616c (patch)
tree0490d682a4d48eb443d68c27692011cd08ee2e09 /src/server/game/Spells/Spell.cpp
parent321f3cc4a7a59874c73ab82d57c2f1c76a820396 (diff)
Core/Spells: Remove spell range increase when caster or target move backwards
Diffstat (limited to 'src/server/game/Spells/Spell.cpp')
-rw-r--r--src/server/game/Spells/Spell.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp
index ad802f400d4..2fe22b2cc7e 100644
--- a/src/server/game/Spells/Spell.cpp
+++ b/src/server/game/Spells/Spell.cpp
@@ -7407,6 +7407,13 @@ SpellCastResult Spell::CheckRange(bool strict) const
return SPELL_CAST_OK;
}
+bool Spell::CanIncreaseRangeByMovement(Unit const* unit)
+{
+ // forward running only
+ return unit->HasUnitMovementFlag(MOVEMENTFLAG_FORWARD | MOVEMENTFLAG_STRAFE_LEFT | MOVEMENTFLAG_STRAFE_RIGHT | MOVEMENTFLAG_FALLING)
+ && !unit->IsWalking();
+}
+
std::pair<float, float> Spell::GetMinMaxRange(bool strict) const
{
float rangeMod = 0.0f;
@@ -7448,7 +7455,7 @@ std::pair<float, float> Spell::GetMinMaxRange(bool strict) const
}
}
- if (target && unitCaster && unitCaster->isMoving() && target->isMoving() && !unitCaster->IsWalking() && !target->IsWalking() &&
+ if (target && unitCaster && CanIncreaseRangeByMovement(target) && CanIncreaseRangeByMovement(unitCaster) &&
((m_spellInfo->RangeEntry->Flags & SPELL_RANGE_MELEE) || target->GetTypeId() == TYPEID_PLAYER))
rangeMod += 8.0f / 3.0f;
}