1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-25 00:23:50 +00:00
openmw-tes3mp/components/esm/loadfact.cpp

95 lines
2.1 KiB
C++
Raw Normal View History

#include "loadfact.hpp"
#include <stdexcept>
#include "esmreader.hpp"
#include "esmwriter.hpp"
#include "defs.hpp"
2012-09-17 07:37:50 +00:00
namespace ESM
{
unsigned int Faction::sRecordId = REC_FACT;
int& Faction::FADTstruct::getSkill (int index, bool ignored)
{
if (index<0 || index>=7)
throw std::logic_error ("skill index out of range");
return mSkills[index];
}
int Faction::FADTstruct::getSkill (int index, bool ignored) const
{
if (index<0 || index>=7)
throw std::logic_error ("skill index out of range");
return mSkills[index];
}
void Faction::load(ESMReader &esm)
{
mName = esm.getHNOString("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())
{
std::string faction = esm.getHNString("ANAM");
int reaction;
esm.getHNT(reaction, "INTV");
mReactions[faction] = reaction;
}
}
void Faction::save(ESMWriter &esm) const
{
esm.writeHNOCString("FNAM", mName);
2013-04-02 10:00:45 +00:00
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);
2013-04-02 10:00:45 +00:00
for (std::map<std::string, int>::const_iterator it = mReactions.begin(); it != mReactions.end(); ++it)
{
esm.writeHNString("ANAM", it->first);
esm.writeHNT("INTV", it->second);
}
}
2013-04-02 10:00:45 +00:00
void Faction::blank()
{
mName.clear();
mData.mAttribute[0] = mData.mAttribute[1] = 0;
2013-04-02 10:00:45 +00:00
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<7; ++i)
mData.mSkills[i] = 0;
2013-04-02 10:00:45 +00:00
mReactions.clear();
}
}