From 7dddbba87deb5a63c5a9ce5bd34129c3df1ce38b Mon Sep 17 00:00:00 2001 From: otsffs <141402668+otsffs@users.noreply.github.com> Date: Fri, 3 Jan 2025 22:45:02 +0800 Subject: [PATCH] fix: Correctly apply actor values in SetActorValues --- Code/client/Games/Skyrim/Actor.cpp | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/Code/client/Games/Skyrim/Actor.cpp b/Code/client/Games/Skyrim/Actor.cpp index 63b1c74f2..b9ffaa5d7 100644 --- a/Code/client/Games/Skyrim/Actor.cpp +++ b/Code/client/Games/Skyrim/Actor.cpp @@ -628,8 +628,14 @@ void Actor::SetActorValue(uint32_t aId, float aValue) noexcept void Actor::ForceActorValue(ActorValueOwner::ForceMode aMode, uint32_t aId, float aValue) noexcept { - const float current = GetActorValue(aId); - actorValueOwner.ForceCurrent(aMode, aId, aValue - current); + float initialValue = aMode == ActorValueOwner::ForceMode::PERMANENT + ? GetActorPermanentValue(aId) + : GetActorValue(aId); + + if (aValue == initialValue) + return; + + actorValueOwner.ForceCurrent(aMode, aId, aValue - initialValue); } Inventory Actor::GetActorInventory() const noexcept @@ -716,16 +722,10 @@ void Actor::SetMagicEquipment(const MagicEquipment& acEquipment) noexcept void Actor::SetActorValues(const ActorValues& acActorValues) noexcept { for (auto& value : acActorValues.ActorMaxValuesList) - { - float current = actorValueOwner.GetValue(value.first); - actorValueOwner.ForceCurrent(ActorValueOwner::ForceMode::PERMANENT, value.first, value.second - current); - } + ForceActorValue(ActorValueOwner::ForceMode::PERMANENT, value.first, value.second); for (auto& value : acActorValues.ActorValuesList) - { - float current = actorValueOwner.GetValue(value.first); - actorValueOwner.ForceCurrent(ActorValueOwner::ForceMode::DAMAGE, value.first, value.second - current); - } + ForceActorValue(ActorValueOwner::ForceMode::DAMAGE, value.first, value.second); } void Actor::SetFactions(const Factions& acFactions) noexcept