#include "statstate.hpp" #include "esmreader.hpp" #include "esmwriter.hpp" namespace ESM { template StatState::StatState() : mBase(0) , mMod(0) , mCurrent(0) , mDamage(0) , mProgress(0) { } template void StatState::load(ESMReader& esm, bool intFallback) { // We changed stats values from integers to floats; ensure backwards compatibility if (intFallback) { int32_t base = 0; esm.getHNT(base, "STBA"); mBase = static_cast(base); int32_t mod = 0; esm.getHNOT(mod, "STMO"); mMod = static_cast(mod); int32_t current = 0; esm.getHNOT(current, "STCU"); mCurrent = static_cast(current); } else { mBase = 0; esm.getHNT(mBase, "STBA"); mMod = 0; esm.getHNOT(mMod, "STMO"); mCurrent = 0; esm.getHNOT(mCurrent, "STCU"); mDamage = 0; esm.getHNOT(mDamage, "STDF"); mProgress = 0; } esm.getHNOT(mDamage, "STDF"); mProgress = 0; esm.getHNOT(mProgress, "STPR"); } template void StatState::save(ESMWriter& esm) const { esm.writeHNT("STBA", mBase); if (mMod != 0) esm.writeHNT("STMO", mMod); if (mCurrent) esm.writeHNT("STCU", mCurrent); if (mDamage) esm.writeHNT("STDF", mDamage); if (mProgress) esm.writeHNT("STPR", mProgress); } template struct StatState; template struct StatState; }