Fix TextArchive, portable BinaryArchive

This commit is contained in:
Matthias Hochsteger 2023-08-23 10:54:45 +02:00
parent 9e4659f194
commit aeadc7f79a
2 changed files with 68 additions and 9 deletions

View File

@ -714,11 +714,19 @@ namespace ngcore
Archive & operator & (long & i) override Archive & operator & (long & i) override
{ {
// for platform independence // for platform independence
int64_t tmp = i; if constexpr (sizeof(long) == 8)
return Write(tmp); return Write(i);
else
return Write(static_cast<int64_t>(i));
} }
Archive & operator & (size_t & i) override Archive & operator & (size_t & i) override
{ return Write(i); } {
// for platform independence
if constexpr (sizeof(size_t) == 8)
return Write(i);
else
return Write(static_cast<uint64_t>(i));
}
Archive & operator & (unsigned char & i) override Archive & operator & (unsigned char & i) override
{ return Write(i); } { return Write(i); }
Archive & operator & (bool & b) override Archive & operator & (bool & b) override
@ -797,13 +805,30 @@ namespace ngcore
{ Read(i); return *this; } { Read(i); return *this; }
Archive & operator & (long & i) override Archive & operator & (long & i) override
{ {
int64_t tmp; // for platform independence
Read(tmp); if constexpr (sizeof(long) == 8)
i = tmp; Read(i);
else
{
int64_t tmp = 0;
Read(tmp);
i = tmp;
}
return *this; return *this;
} }
Archive & operator & (size_t & i) override Archive & operator & (size_t & i) override
{ Read(i); return *this; } {
// for platform independence
if constexpr (sizeof(long) == 8)
Read(i);
else
{
uint64_t tmp = 0;
Read(tmp);
i = tmp;
}
return *this;
}
Archive & operator & (unsigned char & i) override Archive & operator & (unsigned char & i) override
{ Read(i); return *this; } { Read(i); return *this; }
Archive & operator & (bool & b) override Archive & operator & (bool & b) override
@ -861,7 +886,7 @@ namespace ngcore
using Archive::operator&; using Archive::operator&;
Archive & operator & (std::byte & d) override Archive & operator & (std::byte & d) override
{ *stream << std::hex << int(d) << ' '; return *this; } { *stream << int(d) << ' '; return *this; }
Archive & operator & (float & f) override Archive & operator & (float & f) override
{ *stream << f << '\n'; return *this; } { *stream << f << '\n'; return *this; }
Archive & operator & (double & d) override Archive & operator & (double & d) override
@ -916,7 +941,7 @@ namespace ngcore
using Archive::operator&; using Archive::operator&;
Archive & operator & (std::byte & d) override Archive & operator & (std::byte & d) override
{ int tmp; *stream >> std::hex >> tmp; d = std::byte(tmp); return *this; } { int tmp; *stream >> tmp; d = std::byte(tmp); return *this; }
Archive & operator & (float & f) override Archive & operator & (float & f) override
{ *stream >> f; return *this; } { *stream >> f; return *this; }
Archive & operator & (double & d) override Archive & operator & (double & d) override

View File

@ -2,6 +2,8 @@
#include <catch2/catch.hpp> #include <catch2/catch.hpp>
#include <../core/ngcore.hpp> #include <../core/ngcore.hpp>
#include <core/register_archive.hpp> #include <core/register_archive.hpp>
#include <core/logging.hpp>
#include <meshing.hpp>
using namespace ngcore; using namespace ngcore;
using namespace std; using namespace std;
@ -365,3 +367,35 @@ TEST_CASE("TextArchive")
TextInArchive in(stream); TextInArchive in(stream);
testArchive(in, out); testArchive(in, out);
} }
template <typename T>
auto CheckCopyWithArchive(const T * v) {
T * tcopy = nullptr;
auto tstream = make_shared<stringstream>();
TextOutArchive tout(tstream);
tout & v;
TextInArchive tin(tstream);
tin & tcopy;
T *bcopy = nullptr;
auto bstream = make_shared<stringstream>();
BinaryOutArchive bout(bstream);
bout & v;
bout.FlushBuffer();
BinaryInArchive in(bstream);
in & bcopy;
CHECK(*v == *tcopy);
CHECK(*v == *bcopy);
CHECK(*bcopy == *bcopy);
}
TEST_CASE("CopyWithArchive")
{
Array<int> aint{1,2,5,67,23252};
CheckCopyWithArchive(&aint);
std::vector<byte> abyte{byte(1), byte(3), byte(255), byte(0), byte(76)};
CheckCopyWithArchive(&abyte);
}