From ef4a7089e4b8b19ff5dc768a1cccc3e7cc35017b Mon Sep 17 00:00:00 2001 From: elsid Date: Sun, 6 Oct 2019 13:19:55 +0200 Subject: [PATCH] Use template specialization for writeHNT to write raw arrays To avoid passing explicit size argument where it's possible. --- apps/opencs/model/doc/savingstages.cpp | 2 +- components/esm/esmwriter.hpp | 28 ++++++++++++++++++-------- components/esm/loadland.cpp | 8 ++++---- components/esm/player.cpp | 2 +- 4 files changed, 26 insertions(+), 14 deletions(-) diff --git a/apps/opencs/model/doc/savingstages.cpp b/apps/opencs/model/doc/savingstages.cpp index b7eb369d7..44698cd2e 100644 --- a/apps/opencs/model/doc/savingstages.cpp +++ b/apps/opencs/model/doc/savingstages.cpp @@ -356,7 +356,7 @@ void CSMDoc::WriteCellCollectionStage::perform (int stage, Messages& messages) istream >> ignore >> moved.mTarget[0] >> moved.mTarget[1]; refRecord.mRefNum.save (writer, false, "MVRF"); - writer.writeHNT ("CNDT", moved.mTarget, 8); + writer.writeHNT ("CNDT", moved.mTarget); } refRecord.save (writer, false, false, ref.mState == CSMWorld::RecordBase::State_Deleted); diff --git a/components/esm/esmwriter.hpp b/components/esm/esmwriter.hpp index 5d7aebaf9..ba5800f67 100644 --- a/components/esm/esmwriter.hpp +++ b/components/esm/esmwriter.hpp @@ -82,17 +82,23 @@ class ESMWriter endRecord(name); } -private: + template + void writeHNT(const std::string& name, const T (&data)[size]) + { + startSubRecord(name); + writeT(data); + endRecord(name); + } + // Prevent using writeHNT with strings. This already happened by accident and results in // state being discarded without any error on writing or reading it. :( // writeHNString and friends must be used instead. - void writeHNT(const std::string& name, const std::string& data) - { - } - void writeT(const std::string& data) - { - } -public: + void writeHNT(const std::string& name, const std::string& data) = delete; + + void writeT(const std::string& data) = delete; + + template + void writeHNT(const std::string& name, const T (&data)[size], int) = delete; template void writeHNT(const std::string& name, const T& data, int size) @@ -108,6 +114,12 @@ public: write((char*)&data, sizeof(T)); } + template + void writeT(const T (&data)[size]) + { + write(reinterpret_cast(data), size * sizeof(T)); + } + template void writeT(const T& data, size_t size) { diff --git a/components/esm/loadland.cpp b/components/esm/loadland.cpp index 0d9e68eb4..6fbc6735a 100644 --- a/components/esm/loadland.cpp +++ b/components/esm/loadland.cpp @@ -127,7 +127,7 @@ namespace ESM if (mLandData) { if (mDataTypes & Land::DATA_VNML) { - esm.writeHNT("VNML", mLandData->mNormals, sizeof(mLandData->mNormals)); + esm.writeHNT("VNML", mLandData->mNormals); } if (mDataTypes & Land::DATA_VHGT) { VHGT offsets; @@ -175,18 +175,18 @@ namespace ESM wnam[row * LAND_GLOBAL_MAP_LOD_SIZE_SQRT + col] = static_cast(height); } } - esm.writeHNT("WNAM", wnam, 81); + esm.writeHNT("WNAM", wnam); } if (mLandData) { if (mDataTypes & Land::DATA_VCLR) { - esm.writeHNT("VCLR", mLandData->mColours, 3*LAND_NUM_VERTS); + esm.writeHNT("VCLR", mLandData->mColours); } if (mDataTypes & Land::DATA_VTEX) { uint16_t vtex[LAND_NUM_TEXTURES]; transposeTextureData(mLandData->mTextures, vtex); - esm.writeHNT("VTEX", vtex, sizeof(vtex)); + esm.writeHNT("VTEX", vtex); } } diff --git a/components/esm/player.cpp b/components/esm/player.cpp index 7dad34dfb..571a10a8c 100644 --- a/components/esm/player.cpp +++ b/components/esm/player.cpp @@ -58,7 +58,7 @@ void ESM::Player::save (ESMWriter &esm) const mCellId.save (esm); - esm.writeHNT ("LKEP", mLastKnownExteriorPosition, 12); + esm.writeHNT ("LKEP", mLastKnownExteriorPosition); if (mHasMark) {