|
|
@ -1,4 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
#include "npcstats.hpp"
|
|
|
|
#include "npcstats.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
#include "esmreader.hpp"
|
|
|
|
#include "esmreader.hpp"
|
|
|
@ -31,18 +30,43 @@ void ESM::NpcStats::load (ESMReader &esm)
|
|
|
|
esm.getHNOT (mDisposition, "DISP");
|
|
|
|
esm.getHNOT (mDisposition, "DISP");
|
|
|
|
|
|
|
|
|
|
|
|
for (int i=0; i<27; ++i)
|
|
|
|
for (int i=0; i<27; ++i)
|
|
|
|
|
|
|
|
mSkills[i].load (esm);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (esm.peekNextSub("STBA"))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mSkills[i].mRegular.load (esm);
|
|
|
|
// we have deprecated werewolf skills, stored interleaved
|
|
|
|
mSkills[i].mWerewolf.load (esm);
|
|
|
|
// Load into one big vector, then remove every 2nd value
|
|
|
|
|
|
|
|
mWerewolfDeprecatedData = true;
|
|
|
|
|
|
|
|
std::vector<ESM::StatState<int> > skills(mSkills, mSkills + sizeof(mSkills)/sizeof(mSkills[0]));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (int i=0; i<27; ++i)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
ESM::StatState<int> skill;
|
|
|
|
|
|
|
|
skill.load(esm);
|
|
|
|
|
|
|
|
skills.push_back(skill);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int i=0;
|
|
|
|
|
|
|
|
for (std::vector<ESM::StatState<int> >::iterator it = skills.begin(); it != skills.end(); ++i)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (i%2 == 1)
|
|
|
|
|
|
|
|
it = skills.erase(it);
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
++it;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
assert(skills.size() == 27);
|
|
|
|
|
|
|
|
std::copy(skills.begin(), skills.end(), mSkills);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// No longer used
|
|
|
|
bool hasWerewolfAttributes = false;
|
|
|
|
bool hasWerewolfAttributes = false;
|
|
|
|
esm.getHNOT (hasWerewolfAttributes, "HWAT");
|
|
|
|
esm.getHNOT (hasWerewolfAttributes, "HWAT");
|
|
|
|
|
|
|
|
|
|
|
|
if (hasWerewolfAttributes)
|
|
|
|
if (hasWerewolfAttributes)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
ESM::StatState<int> dummy;
|
|
|
|
for (int i=0; i<8; ++i)
|
|
|
|
for (int i=0; i<8; ++i)
|
|
|
|
mWerewolfAttributes[i].load (esm);
|
|
|
|
dummy.load(esm);
|
|
|
|
|
|
|
|
mWerewolfDeprecatedData = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mIsWerewolf = false;
|
|
|
|
mIsWerewolf = false;
|
|
|
@ -112,10 +136,7 @@ void ESM::NpcStats::save (ESMWriter &esm) const
|
|
|
|
esm.writeHNT ("DISP", mDisposition);
|
|
|
|
esm.writeHNT ("DISP", mDisposition);
|
|
|
|
|
|
|
|
|
|
|
|
for (int i=0; i<27; ++i)
|
|
|
|
for (int i=0; i<27; ++i)
|
|
|
|
{
|
|
|
|
mSkills[i].save (esm);
|
|
|
|
mSkills[i].mRegular.save (esm);
|
|
|
|
|
|
|
|
mSkills[i].mWerewolf.save (esm);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (mIsWerewolf)
|
|
|
|
if (mIsWerewolf)
|
|
|
|
esm.writeHNT ("WOLF", mIsWerewolf);
|
|
|
|
esm.writeHNT ("WOLF", mIsWerewolf);
|
|
|
@ -147,6 +168,7 @@ void ESM::NpcStats::save (ESMWriter &esm) const
|
|
|
|
|
|
|
|
|
|
|
|
void ESM::NpcStats::blank()
|
|
|
|
void ESM::NpcStats::blank()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
mWerewolfDeprecatedData = false;
|
|
|
|
mIsWerewolf = false;
|
|
|
|
mIsWerewolf = false;
|
|
|
|
mDisposition = 0;
|
|
|
|
mDisposition = 0;
|
|
|
|
mBounty = 0;
|
|
|
|
mBounty = 0;
|
|
|
|