openmw-tes3coop/components/esm/loadregn.cpp

50 lines
1.1 KiB
C++
Raw Normal View History

#include "loadregn.hpp"
#include "esmreader.hpp"
#include "esmwriter.hpp"
2012-09-17 07:37:50 +00:00
namespace ESM
{
void Region::load(ESMReader &esm)
{
2012-09-17 07:37:50 +00:00
mName = esm.getHNString("FNAM");
if (esm.getVer() == VER_12)
2012-09-17 07:37:50 +00:00
esm.getHNExact(&mData, sizeof(mData) - 2, "WEAT");
else if (esm.getVer() == VER_13)
2012-09-17 07:37:50 +00:00
esm.getHNExact(&mData, sizeof(mData), "WEAT");
else
esm.fail("Don't know what to do in this version");
2012-09-17 07:37:50 +00:00
mSleepList = esm.getHNOString("BNAM");
2012-09-17 07:37:50 +00:00
esm.getHNT(mMapColor, "CNAM");
while (esm.hasMoreSubs())
{
SoundRef sr;
esm.getHNT(sr, "SNAM", 33);
2012-09-17 07:37:50 +00:00
mSoundList.push_back(sr);
}
}
void Region::save(ESMWriter &esm)
{
2012-09-17 07:37:50 +00:00
esm.writeHNCString("FNAM", mName);
if (esm.getVersion() == VER_12)
2012-09-17 07:37:50 +00:00
esm.writeHNT("WEAT", mData, sizeof(mData) - 2);
else
2012-09-17 07:37:50 +00:00
esm.writeHNT("WEAT", mData);
2012-09-17 07:37:50 +00:00
esm.writeHNOCString("BNAM", mSleepList);
2012-09-17 07:37:50 +00:00
esm.writeHNT("CNAM", mMapColor);
for (std::vector<SoundRef>::iterator it = mSoundList.begin(); it != mSoundList.end(); ++it)
{
esm.writeHNT<SoundRef>("SNAM", *it);
}
}
}