diff options
author | Kae <80987908+Novaenia@users.noreply.github.com> | 2025-01-21 09:07:37 +1100 |
---|---|---|
committer | Kae <80987908+Novaenia@users.noreply.github.com> | 2025-01-21 09:07:37 +1100 |
commit | 3f8b480b21538a97e6256ad7a0fcb95cb1b27e46 (patch) | |
tree | 9c0353ebb114127fd9ca11d1339e478b994fb434 /source/game/StarHumanoid.cpp | |
parent | 449d05d195cf7b3215a2338afa593bfcef052796 (diff) |
let chest and leg armor override humanoid config values
Diffstat (limited to 'source/game/StarHumanoid.cpp')
-rw-r--r-- | source/game/StarHumanoid.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/source/game/StarHumanoid.cpp b/source/game/StarHumanoid.cpp index 2acc632..e446142 100644 --- a/source/game/StarHumanoid.cpp +++ b/source/game/StarHumanoid.cpp @@ -251,7 +251,8 @@ bool& Humanoid::globalHeadRotation() { }; Humanoid::Humanoid(Json const& config) { - loadConfig(config); + m_baseConfig = config; + loadConfig(JsonObject()); m_twoHanded = false; m_primaryHand.holdingItem = false; @@ -293,7 +294,12 @@ HumanoidIdentity const& Humanoid::identity() const { return m_identity; } -void Humanoid::loadConfig(Json const& config) { +void Humanoid::loadConfig(Json merger) { + if (m_mergeConfig == merger) + return; + + m_mergeConfig = merger; + auto config = jsonMerge(m_baseConfig, merger); m_timing = HumanoidTiming(config.getObject("humanoidTiming")); m_globalOffset = jsonToVec2F(config.get("globalOffset")) / TilePixels; |