1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-01 03:21:41 +00:00
OpenMW/components/esm/loadnpc.cpp

97 lines
2.3 KiB
C++
Raw Normal View History

#include "loadnpc.hpp"
#include "esmreader.hpp"
#include "esmwriter.hpp"
2012-09-17 07:37:50 +00:00
namespace ESM
{
void NPC::load(ESMReader &esm)
{
2012-09-17 07:37:50 +00:00
mNpdt52.mGold = -10;
2012-09-17 07:37:50 +00:00
mModel = esm.getHNOString("MODL");
mName = esm.getHNOString("FNAM");
2012-09-17 07:37:50 +00:00
mRace = esm.getHNString("RNAM");
mClass = esm.getHNString("CNAM");
mFaction = esm.getHNString("ANAM");
mHead = esm.getHNString("BNAM");
mHair = esm.getHNString("KNAM");
2012-09-17 07:37:50 +00:00
mScript = esm.getHNOString("SCRI");
esm.getSubNameIs("NPDT");
esm.getSubHeader();
if (esm.getSubSize() == 52)
{
2012-09-17 07:37:50 +00:00
mNpdtType = 52;
esm.getExact(&mNpdt52, 52);
}
else if (esm.getSubSize() == 12)
{
2012-09-17 07:37:50 +00:00
mNpdtType = 12;
esm.getExact(&mNpdt12, 12);
}
else
esm.fail("NPC_NPDT must be 12 or 52 bytes long");
2012-09-17 07:37:50 +00:00
esm.getHNT(mFlags, "FLAG");
2012-09-17 07:37:50 +00:00
mInventory.load(esm);
mSpells.load(esm);
if (esm.isNextSub("AIDT"))
{
2012-08-29 17:35:06 +00:00
esm.getHExact(&mAiData, sizeof(mAiData));
mHasAI= true;
}
else
2012-08-29 17:35:06 +00:00
mHasAI = false;
2012-08-29 10:01:10 +00:00
while (esm.isNextSub("DODT") || esm.isNextSub("DNAM")) {
if (esm.retSubName() == 0x54444f44) { // DODT struct
Dest dodt;
2012-08-29 17:35:06 +00:00
esm.getHExact(&dodt.mPos, 24);
mTransport.push_back(dodt);
2012-08-29 10:01:10 +00:00
} else if (esm.retSubName() == 0x4d414e44) { // DNAM struct
2012-08-29 17:35:06 +00:00
mTransport.back().mCellName = esm.getHString();
2012-08-29 10:01:10 +00:00
}
}
2012-08-29 17:35:06 +00:00
mAiPackage.load(esm);
esm.skipRecord();
}
void NPC::save(ESMWriter &esm)
{
2012-09-17 07:37:50 +00:00
esm.writeHNOCString("MODL", mModel);
esm.writeHNOCString("FNAM", mName);
esm.writeHNCString("RNAM", mRace);
esm.writeHNCString("CNAM", mClass);
esm.writeHNCString("ANAM", mFaction);
esm.writeHNCString("BNAM", mHead);
esm.writeHNCString("KNAM", mHair);
esm.writeHNOCString("SCRI", mScript);
2012-09-17 07:37:50 +00:00
if (mNpdtType == 52)
esm.writeHNT("NPDT", mNpdt52, 52);
else if (mNpdtType == 12)
esm.writeHNT("NPDT", mNpdt12, 12);
2012-09-17 07:37:50 +00:00
esm.writeHNT("FLAG", mFlags);
2012-09-17 07:37:50 +00:00
mInventory.save(esm);
mSpells.save(esm);
2012-09-18 15:30:19 +00:00
if (mHasAI) {
esm.writeHNT("AIDT", mAiData, sizeof(mAiData));
}
typedef std::vector<Dest>::iterator DestIter;
for (DestIter it = mTransport.begin(); it != mTransport.end(); ++it) {
esm.writeHNT("DODT", it->mPos, sizeof(it->mPos));
esm.writeHNOCString("DNAM", it->mCellName);
}
2012-09-17 07:37:50 +00:00
mAiPackage.save(esm);
}
}