2013-03-12 08:16:03 +00:00
|
|
|
|
|
|
|
#include "loadtes3.hpp"
|
|
|
|
|
|
|
|
#include "esmcommon.hpp"
|
|
|
|
#include "esmreader.hpp"
|
|
|
|
#include "esmwriter.hpp"
|
2013-09-24 11:17:28 +00:00
|
|
|
#include "defs.hpp"
|
2013-03-12 08:16:03 +00:00
|
|
|
|
|
|
|
void ESM::Header::blank()
|
|
|
|
{
|
|
|
|
mData.version = ESM::VER_13;
|
|
|
|
mData.type = 0;
|
|
|
|
mData.author.assign ("");
|
|
|
|
mData.desc.assign ("");
|
|
|
|
mData.records = 0;
|
2013-03-12 13:33:35 +00:00
|
|
|
mFormat = CurrentFormat;
|
2013-09-27 09:36:06 +00:00
|
|
|
mMaster.clear();
|
2013-03-12 08:16:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void ESM::Header::load (ESMReader &esm)
|
|
|
|
{
|
2013-03-12 13:33:35 +00:00
|
|
|
if (esm.isNextSub ("FORM"))
|
|
|
|
{
|
|
|
|
esm.getHT (mFormat);
|
|
|
|
if (mFormat<0)
|
|
|
|
esm.fail ("invalid format code");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
mFormat = 0;
|
|
|
|
|
2013-12-21 08:33:05 +00:00
|
|
|
if (esm.isNextSub("HEDR"))
|
|
|
|
{
|
|
|
|
esm.getSubHeader();
|
|
|
|
esm.getT(mData.version);
|
|
|
|
esm.getT(mData.type);
|
|
|
|
mData.author.assign(esm.getString(sizeof(mData.author.name)));
|
|
|
|
mData.desc.assign(esm.getString(sizeof(mData.desc.name)));
|
|
|
|
esm.getT(mData.records);
|
|
|
|
}
|
2013-11-19 12:44:18 +00:00
|
|
|
|
2013-03-12 08:16:03 +00:00
|
|
|
while (esm.isNextSub ("MAST"))
|
|
|
|
{
|
|
|
|
MasterData m;
|
|
|
|
m.name = esm.getHString();
|
|
|
|
m.size = esm.getHNLong ("DATA");
|
|
|
|
mMaster.push_back (m);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ESM::Header::save (ESMWriter &esm)
|
|
|
|
{
|
2013-03-12 13:33:35 +00:00
|
|
|
if (mFormat>0)
|
|
|
|
esm.writeHNT ("FORM", mFormat);
|
|
|
|
|
2013-11-19 12:44:18 +00:00
|
|
|
esm.writeHNT ("HEDR", mData, 300);
|
|
|
|
|
2013-03-12 08:16:03 +00:00
|
|
|
for (std::vector<Header::MasterData>::iterator iter = mMaster.begin();
|
|
|
|
iter != mMaster.end(); ++iter)
|
|
|
|
{
|
|
|
|
esm.writeHNCString ("MAST", iter->name);
|
|
|
|
esm.writeHNT ("DATA", iter->size);
|
|
|
|
}
|
2013-12-21 08:33:05 +00:00
|
|
|
}
|