#include "loadfact.hpp" #include "esmreader.hpp" #include "esmwriter.hpp" namespace ESM { void Faction::load(ESMReader &esm) { mName = esm.getHNString("FNAM"); // Read rank names. These are optional. int i = 0; while (esm.isNextSub("RNAM") && i < 10) mRanks[i++] = esm.getHString(); // Main data struct esm.getHNT(mData, "FADT", 240); if (mData.mIsHidden > 1) esm.fail("Unknown flag!"); // Read faction response values while (esm.hasMoreSubs()) { Reaction r; r.mFaction = esm.getHNString("ANAM"); esm.getHNT(r.mReaction, "INTV"); mReactions.push_back(r); } } void Faction::save(ESMWriter &esm) { esm.writeHNCString("FNAM", mName); for (int i = 0; i < 10; i++) { if (mRanks[i].empty()) break; esm.writeHNString("RNAM", mRanks[i], 32); } esm.writeHNT("FADT", mData, 240); for (std::vector::iterator it = mReactions.begin(); it != mReactions.end(); ++it) { esm.writeHNString("ANAM", it->mFaction); esm.writeHNT("INTV", it->mReaction); } } void Faction::blank() { mName.clear(); mData.mAttribute1 = mData.mAttribute2 = 0; mData.mUnknown = -1; mData.mIsHidden = 0; for (int i=0; i<10; ++i) { mData.mRankData[i].mAttribute1 = mData.mRankData[i].mAttribute2 = 0; mData.mRankData[i].mSkill1 = mData.mRankData[i].mSkill2 = 0; mData.mRankData[i].mFactReaction = 0; mRanks[i].clear(); } for (int i=0; i<6; ++i) mData.mSkillID[i] = 0; mReactions.clear(); } }