aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/server/game/Entities/Unit/Unit.cpp5
-rw-r--r--src/server/game/Spells/Spell.cpp5
2 files changed, 8 insertions, 2 deletions
diff --git a/src/server/game/Entities/Unit/Unit.cpp b/src/server/game/Entities/Unit/Unit.cpp
index b09d4e6f5d9..7aab5386818 100644
--- a/src/server/game/Entities/Unit/Unit.cpp
+++ b/src/server/game/Entities/Unit/Unit.cpp
@@ -3007,9 +3007,12 @@ void Unit::ProcessTerrainStatusUpdate(ZLiquidStatus status, Optional<LiquidData>
if (_lastLiquid && _lastLiquid->SpellID)
RemoveAurasDueToSpell(_lastLiquid->SpellID);
Player* player = GetCharmerOrOwnerPlayerOrPlayerItself();
+
+ // Set _lastLiquid before casting liquid spell to avoid infinite loops
+ _lastLiquid = curLiquid;
+
if (curLiquid && curLiquid->SpellID && (!player || !player->IsGameMaster()))
CastSpell(this, curLiquid->SpellID, true);
- _lastLiquid = curLiquid;
// mount capability depends on liquid state change
UpdateMountCapability();
diff --git a/src/server/game/Spells/Spell.cpp b/src/server/game/Spells/Spell.cpp
index 4e70226bca0..a13a22044c9 100644
--- a/src/server/game/Spells/Spell.cpp
+++ b/src/server/game/Spells/Spell.cpp
@@ -3953,7 +3953,10 @@ void Spell::finish(bool ok)
if (spellInfo && spellInfo->IconFileDataId == 134230)
{
TC_LOG_DEBUG("spells", "Statue %s is unsummoned in spell %d finish", unitCaster->GetGUID().ToString().c_str(), m_spellInfo->Id);
- unitCaster->setDeathState(JUST_DIED);
+ // Avoid infinite loops with setDeathState(JUST_DIED) being called over and over
+ // It might make sense to do this check in Unit::setDeathState() and all overloaded functions
+ if (unitCaster->getDeathState() != JUST_DIED)
+ unitCaster->setDeathState(JUST_DIED);
return;
}
}