aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2024-03-10 00:34:23 +0100
committerfunjoker <funjoker109@gmail.com>2024-03-25 20:12:53 +0100
commit97df861c52c21d032ba65a1702b71eb3bdd975f7 (patch)
treedb98108ffd4746e7ed85acea0e3cc553b14fbddd
parent9dca7a8041ca9f5c89ce3ab84ff5f90e9831d020 (diff)
Core/Auras: Update visible aura immediately during spell cast instead of waiting for next update tick
(cherry picked from commit 62dc916184d5d32b26a2d331d84d3cae481040fb)
-rw-r--r--src/server/game/Entities/Unit/Unit.h5
-rw-r--r--src/server/game/Spells/Spell.cpp6
2 files changed, 9 insertions, 2 deletions
diff --git a/src/server/game/Entities/Unit/Unit.h b/src/server/game/Entities/Unit/Unit.h
index 7e647d74b89..86040e3dcbd 100644
--- a/src/server/game/Entities/Unit/Unit.h
+++ b/src/server/game/Entities/Unit/Unit.h
@@ -1528,10 +1528,11 @@ class TC_GAME_API Unit : public WorldObject
uint32 m_lastSanctuaryTime;
VisibleAuraContainer const& GetVisibleAuras() const { return m_visibleAuras; }
- bool HasVisibleAura(AuraApplication* aurApp) const { return m_visibleAuras.count(aurApp) > 0; }
+ bool HasVisibleAura(AuraApplication* aurApp) const { return m_visibleAuras.contains(aurApp); }
void SetVisibleAura(AuraApplication* aurApp);
- void SetVisibleAuraUpdate(AuraApplication* aurApp) { m_visibleAurasToUpdate.insert(aurApp); }
void RemoveVisibleAura(AuraApplication* aurApp);
+ void SetVisibleAuraUpdate(AuraApplication* aurApp) { m_visibleAurasToUpdate.insert(aurApp); }
+ void RemoveVisibleAuraUpdate(AuraApplication* aurApp) { m_visibleAurasToUpdate.erase(aurApp); }
bool HasInterruptFlag(SpellAuraInterruptFlags flags) const { return m_interruptMask.HasFlag(flags); }
bool HasInterruptFlag(SpellAuraInterruptFlags2 flags) const { return m_interruptMask2.HasFlag(flags); }
diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp
index 66f710eda7c..53f3f79bc92 100644
--- a/src/server/game/Spells/Spell.cpp
+++ b/src/server/game/Spells/Spell.cpp
@@ -3026,6 +3026,12 @@ void Spell::TargetInfo::DoDamageAndTriggers(Spell* spell)
if (effMask)
_spellHitTarget->_ApplyAura(aurApp, effMask);
+
+ if (aurApp->IsNeedClientUpdate() && aurApp->GetRemoveMode() == AURA_REMOVE_NONE)
+ {
+ aurApp->ClientUpdate(false);
+ _spellHitTarget->RemoveVisibleAuraUpdate(aurApp);
+ }
}
}