From f02ed0d6215dad749dc3cdfaa2ed369330184339 Mon Sep 17 00:00:00 2001 From: David Cernat Date: Sat, 10 Jun 2017 09:28:35 +0300 Subject: [PATCH] [Server] Add script functions for getting and setting actor dynamic stat modifiers --- apps/openmw-mp/Script/Functions/Actors.cpp | 30 ++++++++++++++++++++++ apps/openmw-mp/Script/Functions/Actors.hpp | 12 +++++++++ 2 files changed, 42 insertions(+) diff --git a/apps/openmw-mp/Script/Functions/Actors.cpp b/apps/openmw-mp/Script/Functions/Actors.cpp index 6827809fc..baa71faf9 100644 --- a/apps/openmw-mp/Script/Functions/Actors.cpp +++ b/apps/openmw-mp/Script/Functions/Actors.cpp @@ -113,6 +113,11 @@ double ActorFunctions::GetActorHealthCurrent(unsigned int i) noexcept return readActorList->baseActors.at(i).creatureStats.mDynamic[0].mCurrent; } +double ActorFunctions::GetActorHealthModified(unsigned int i) noexcept +{ + return readActorList->baseActors.at(i).creatureStats.mDynamic[0].mMod; +} + double ActorFunctions::GetActorMagickaBase(unsigned int i) noexcept { return readActorList->baseActors.at(i).creatureStats.mDynamic[1].mBase; @@ -123,6 +128,11 @@ double ActorFunctions::GetActorMagickaCurrent(unsigned int i) noexcept return readActorList->baseActors.at(i).creatureStats.mDynamic[1].mCurrent; } +double ActorFunctions::GetActorMagickaModified(unsigned int i) noexcept +{ + return readActorList->baseActors.at(i).creatureStats.mDynamic[1].mMod; +} + double ActorFunctions::GetActorFatigueBase(unsigned int i) noexcept { return readActorList->baseActors.at(i).creatureStats.mDynamic[2].mBase; @@ -133,6 +143,11 @@ double ActorFunctions::GetActorFatigueCurrent(unsigned int i) noexcept return readActorList->baseActors.at(i).creatureStats.mDynamic[2].mCurrent; } +double ActorFunctions::GetActorFatigueModified(unsigned int i) noexcept +{ + return readActorList->baseActors.at(i).creatureStats.mDynamic[2].mMod; +} + const char *ActorFunctions::GetActorEquipmentItemRefId(unsigned int i, unsigned short slot) noexcept { return readActorList->baseActors.at(i).equipedItems[slot].refId.c_str(); @@ -212,6 +227,11 @@ void ActorFunctions::SetActorHealthCurrent(double value) noexcept tempActor.creatureStats.mDynamic[0].mCurrent = value; } +void ActorFunctions::SetActorHealthModified(double value) noexcept +{ + tempActor.creatureStats.mDynamic[0].mMod = value; +} + void ActorFunctions::SetActorMagickaBase(double value) noexcept { tempActor.creatureStats.mDynamic[1].mBase = value; @@ -222,6 +242,11 @@ void ActorFunctions::SetActorMagickaCurrent(double value) noexcept tempActor.creatureStats.mDynamic[1].mCurrent = value; } +void ActorFunctions::SetActorMagickaModified(double value) noexcept +{ + tempActor.creatureStats.mDynamic[1].mMod = value; +} + void ActorFunctions::SetActorFatigueBase(double value) noexcept { tempActor.creatureStats.mDynamic[2].mBase = value; @@ -232,6 +257,11 @@ void ActorFunctions::SetActorFatigueCurrent(double value) noexcept tempActor.creatureStats.mDynamic[2].mCurrent = value; } +void ActorFunctions::SetActorFatigueModified(double value) noexcept +{ + tempActor.creatureStats.mDynamic[2].mMod = value; +} + void ActorFunctions::EquipActorItem(unsigned short slot, const char *refId, unsigned int count, int charge) noexcept { tempActor.equipedItems[slot].refId = refId; diff --git a/apps/openmw-mp/Script/Functions/Actors.hpp b/apps/openmw-mp/Script/Functions/Actors.hpp index 9b8271fa5..4a2544e80 100644 --- a/apps/openmw-mp/Script/Functions/Actors.hpp +++ b/apps/openmw-mp/Script/Functions/Actors.hpp @@ -23,10 +23,13 @@ \ {"GetActorHealthBase", ActorFunctions::GetActorHealthBase},\ {"GetActorHealthCurrent", ActorFunctions::GetActorHealthCurrent},\ + {"GetActorHealthModified", ActorFunctions::GetActorHealthModified},\ {"GetActorMagickaBase", ActorFunctions::GetActorMagickaBase},\ {"GetActorMagickaCurrent", ActorFunctions::GetActorMagickaCurrent},\ + {"GetActorMagickaModified", ActorFunctions::GetActorMagickaModified},\ {"GetActorFatigueBase", ActorFunctions::GetActorFatigueBase},\ {"GetActorFatigueCurrent", ActorFunctions::GetActorFatigueCurrent},\ + {"GetActorFatigueModified", ActorFunctions::GetActorFatigueModified},\ \ {"GetActorEquipmentItemRefId", ActorFunctions::GetActorEquipmentItemRefId},\ {"GetActorEquipmentItemCount", ActorFunctions::GetActorEquipmentItemCount},\ @@ -48,10 +51,13 @@ \ {"SetActorHealthBase", ActorFunctions::SetActorHealthBase},\ {"SetActorHealthCurrent", ActorFunctions::SetActorHealthCurrent},\ + {"SetActorHealthModified", ActorFunctions::SetActorHealthModified},\ {"SetActorMagickaBase", ActorFunctions::SetActorMagickaBase},\ {"SetActorMagickaCurrent", ActorFunctions::SetActorMagickaCurrent},\ + {"SetActorMagickaModified", ActorFunctions::SetActorMagickaModified},\ {"SetActorFatigueBase", ActorFunctions::SetActorFatigueBase},\ {"SetActorFatigueCurrent", ActorFunctions::SetActorFatigueCurrent},\ + {"SetActorFatigueModified", ActorFunctions::SetActorFatigueModified},\ \ {"EquipActorItem", ActorFunctions::EquipActorItem},\ {"UnequipActorItem", ActorFunctions::UnequipActorItem},\ @@ -90,10 +96,13 @@ public: static double GetActorHealthBase(unsigned int i) noexcept; static double GetActorHealthCurrent(unsigned int i) noexcept; + static double GetActorHealthModified(unsigned int i) noexcept; static double GetActorMagickaBase(unsigned int i) noexcept; static double GetActorMagickaCurrent(unsigned int i) noexcept; + static double GetActorMagickaModified(unsigned int i) noexcept; static double GetActorFatigueBase(unsigned int i) noexcept; static double GetActorFatigueCurrent(unsigned int i) noexcept; + static double GetActorFatigueModified(unsigned int i) noexcept; static const char *GetActorEquipmentItemRefId(unsigned int i, unsigned short slot) noexcept; static int GetActorEquipmentItemCount(unsigned int i, unsigned short slot) noexcept; @@ -115,10 +124,13 @@ public: static void SetActorHealthBase(double value) noexcept; static void SetActorHealthCurrent(double value) noexcept; + static void SetActorHealthModified(double value) noexcept; static void SetActorMagickaBase(double value) noexcept; static void SetActorMagickaCurrent(double value) noexcept; + static void SetActorMagickaModified(double value) noexcept; static void SetActorFatigueBase(double value) noexcept; static void SetActorFatigueCurrent(double value) noexcept; + static void SetActorFatigueModified(double value) noexcept; static void EquipActorItem(unsigned short slot, const char* refId, unsigned int count, int charge) noexcept; static void UnequipActorItem(unsigned short slot) noexcept;