openmw-tes3coop/components/esm/loadfact.cpp

55 lines
1.1 KiB
C++
Raw Normal View History

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