diff --git a/apps/esmtool/record.cpp b/apps/esmtool/record.cpp index bafad2d16b..607e8e8c25 100644 --- a/apps/esmtool/record.cpp +++ b/apps/esmtool/record.cpp @@ -4,6 +4,8 @@ #include #include +#include +#include #include namespace @@ -213,11 +215,19 @@ namespace std::cout << " Destination Cell: " << dest.mCellName << std::endl; } } - } namespace EsmTool { + void CellState::load(ESM::ESMReader& reader, bool& deleted) + { + mCellState.mId.load(reader); + mCellState.load(reader); + if (mCellState.mHasFogOfWar) + mFogState.load(reader); + deleted = false; + reader.skipRecord(); + } std::unique_ptr RecordBase::create(const ESM::NAME type) { @@ -435,6 +445,11 @@ namespace EsmTool record = std::make_unique>(); break; } + case ESM::REC_CSTA: + { + record = std::make_unique>(); + break; + } default: break; } @@ -1339,6 +1354,38 @@ namespace EsmTool std::cout << " Deleted: " << mIsDeleted << std::endl; } + template <> + void Record::print() + { + std::cout << " Id:" << std::endl; + std::cout << " Worldspace: " << mData.mCellState.mId.mWorldspace << std::endl; + std::cout << " Index:" << std::endl; + std::cout << " X: " << mData.mCellState.mId.mIndex.mX << std::endl; + std::cout << " Y: " << mData.mCellState.mId.mIndex.mY << std::endl; + std::cout << " Paged: " << mData.mCellState.mId.mPaged << std::endl; + std::cout << " WaterLevel: " << mData.mCellState.mWaterLevel << std::endl; + std::cout << " HasFogOfWar: " << mData.mCellState.mHasFogOfWar << std::endl; + std::cout << " LastRespawn:" << std::endl; + std::cout << " Day:" << mData.mCellState.mLastRespawn.mDay << std::endl; + std::cout << " Hour:" << mData.mCellState.mLastRespawn.mHour << std::endl; + if (mData.mCellState.mHasFogOfWar) + { + std::cout << " NorthMarkerAngle: " << mData.mFogState.mNorthMarkerAngle << std::endl; + std::cout << " Bounds:" << std::endl; + std::cout << " MinX: " << mData.mFogState.mBounds.mMinX << std::endl; + std::cout << " MinY: " << mData.mFogState.mBounds.mMinY << std::endl; + std::cout << " MaxX: " << mData.mFogState.mBounds.mMaxX << std::endl; + std::cout << " MaxY: " << mData.mFogState.mBounds.mMaxY << std::endl; + for (const ESM::FogTexture& fogTexture : mData.mFogState.mFogTextures) + { + std::cout << " FogTexture:" << std::endl; + std::cout << " X: " << fogTexture.mX << std::endl; + std::cout << " Y: " << fogTexture.mY << std::endl; + std::cout << " ImageData: (" << fogTexture.mImageData.size() << ")" << std::endl; + } + } + } + template <> std::string Record::getId() const { @@ -1369,4 +1416,13 @@ namespace EsmTool return std::string(); // No ID for Skill record } + template <> + std::string Record::getId() const + { + std::ostringstream stream; + stream << mData.mCellState.mId.mWorldspace << " " << mData.mCellState.mId.mIndex.mX << " " + << mData.mCellState.mId.mIndex.mY << " " << mData.mCellState.mId.mPaged; + return stream.str(); + } + } // end namespace diff --git a/apps/esmtool/record.hpp b/apps/esmtool/record.hpp index 1f178c0016..e7d5240c51 100644 --- a/apps/esmtool/record.hpp +++ b/apps/esmtool/record.hpp @@ -5,6 +5,8 @@ #include #include +#include +#include namespace ESM { @@ -58,6 +60,16 @@ namespace EsmTool } }; + struct CellState + { + ESM::CellState mCellState; + ESM::FogState mFogState; + + void load(ESM::ESMReader& reader, bool& deleted); + + void save(ESM::ESMWriter& /*writer*/, bool /*deleted*/) {} + }; + template class Record : public RecordBase { @@ -91,6 +103,8 @@ namespace EsmTool std::string Record::getId() const; template <> std::string Record::getId() const; + template <> + std::string Record::getId() const; template <> void Record::print(); @@ -176,6 +190,8 @@ namespace EsmTool void Record::print(); template <> void Record::print(); + template <> + void Record::print(); } #endif diff --git a/components/esm3/fogstate.cpp b/components/esm3/fogstate.cpp index 4f25c33c13..65f391cefb 100644 --- a/components/esm3/fogstate.cpp +++ b/components/esm3/fogstate.cpp @@ -69,9 +69,9 @@ namespace ESM esm.getT(tex.mX); esm.getT(tex.mY); - size_t imageSize = esm.getSubSize() - sizeof(int) * 2; + const std::size_t imageSize = esm.getSubSize() - sizeof(int) * 2; tex.mImageData.resize(imageSize); - esm.getExact(&tex.mImageData[0], imageSize); + esm.getExact(tex.mImageData.data(), imageSize); if (dataFormat <= MaxOldForOfWarFormatVersion) convertFogOfWar(tex.mImageData); @@ -92,7 +92,7 @@ namespace ESM esm.startSubRecord("FTEX"); esm.writeT(it->mX); esm.writeT(it->mY); - esm.write(&it->mImageData[0], it->mImageData.size()); + esm.write(it->mImageData.data(), it->mImageData.size()); esm.endRecord("FTEX"); } }