1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-20 06:53:52 +00:00

Merge pull request #2756 from elsid/write_hnt_arrays

Use template specialization for writeHNT to write raw arrays
This commit is contained in:
Andrei Kortunov 2020-04-04 14:03:46 +04:00 committed by GitHub
commit 3a1b2307ce
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 26 additions and 14 deletions

View file

@ -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);

View file

@ -82,17 +82,23 @@ class ESMWriter
endRecord(name);
}
private:
template<typename T, std::size_t size>
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<typename T, std::size_t size>
void writeHNT(const std::string& name, const T (&data)[size], int) = delete;
template<typename T>
void writeHNT(const std::string& name, const T& data, int size)
@ -108,6 +114,12 @@ public:
write((char*)&data, sizeof(T));
}
template<typename T, std::size_t size>
void writeT(const T (&data)[size])
{
write(reinterpret_cast<const char*>(data), size * sizeof(T));
}
template<typename T>
void writeT(const T& data, size_t size)
{

View file

@ -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<signed char>(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);
}
}

View file

@ -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)
{