#include "loadregn.hpp" #include "esmreader.hpp" #include "esmwriter.hpp" #include "defs.hpp" #include "util.hpp" namespace ESM { unsigned int Region::sRecordId = REC_REGN; Region::Region() : mIsDeleted(false) {} void Region::load(ESMReader &esm) { mIsDeleted = readDeleSubRecord(esm); mId = esm.getHNString("NAME"); mName = esm.getHNOString("FNAM"); esm.getSubNameIs("WEAT"); esm.getSubHeader(); if (esm.getVer() == VER_12) { mData.mA = 0; mData.mB = 0; esm.getExact(&mData, sizeof(mData) - 2); } else if (esm.getVer() == VER_13) { // May include the additional two bytes (but not necessarily) if (esm.getSubSize() == sizeof(mData)) esm.getExact(&mData, sizeof(mData)); else { mData.mA = 0; mData.mB = 0; esm.getExact(&mData, sizeof(mData)-2); } } else esm.fail("Don't know what to do in this version"); mSleepList = esm.getHNOString("BNAM"); esm.getHNT(mMapColor, "CNAM"); mSoundList.clear(); while (esm.hasMoreSubs()) { SoundRef sr; esm.getHNT(sr, "SNAM", 33); mSoundList.push_back(sr); } } void Region::save(ESMWriter &esm) const { if (mIsDeleted) { writeDeleSubRecord(esm); } esm.writeHNString("NAME", mId); esm.writeHNOCString("FNAM", mName); if (esm.getVersion() == VER_12) esm.writeHNT("WEAT", mData, sizeof(mData) - 2); else esm.writeHNT("WEAT", mData); esm.writeHNOCString("BNAM", mSleepList); esm.writeHNT("CNAM", mMapColor); for (std::vector::const_iterator it = mSoundList.begin(); it != mSoundList.end(); ++it) { esm.writeHNT("SNAM", *it); } } void Region::blank() { mName.clear(); mData.mClear = mData.mCloudy = mData.mFoggy = mData.mOvercast = mData.mRain = mData.mThunder = mData.mAsh, mData.mBlight = mData.mA = mData.mB = 0; mMapColor = 0; mName.clear(); mSleepList.clear(); mSoundList.clear(); mIsDeleted = false; } }