aboutsummaryrefslogtreecommitdiff
path: root/core/src/Utils/IO/DataStream.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'core/src/Utils/IO/DataStream.hpp')
-rw-r--r--core/src/Utils/IO/DataStream.hpp184
1 files changed, 93 insertions, 91 deletions
diff --git a/core/src/Utils/IO/DataStream.hpp b/core/src/Utils/IO/DataStream.hpp
index a88fe07..b965263 100644
--- a/core/src/Utils/IO/DataStream.hpp
+++ b/core/src/Utils/IO/DataStream.hpp
@@ -2,8 +2,10 @@
#include "cplt_fwd.hpp"
+#include <bit>
#include <cstddef>
#include <cstdint>
+#include <fstream>
#include <span>
class SerializationStreamProxy
@@ -18,28 +20,16 @@ public:
DataStream* Stream;
template <class T>
- void Bytes(size_t byteCount, T* buffer) const
- {
- Stream->WriteBytes(byteCount, buffer);
- }
+ void Bytes(size_t byteCount, T* buffer) const;
template <class T>
- void Value(T t) const
- {
- Stream->Write(t);
- }
+ void Value(T t) const;
template <class T>
- void Object(T& obj) const
- {
- Stream->WriteObject(obj);
- }
+ void Object(T& obj) const;
template <class TObject, class TAdapter>
- void ObjectAdapted(TObject& obj, TAdapter adapter) const
- {
- Stream->WriteObjectAdapted(obj, adapter);
- }
+ void ObjectAdapted(TObject& obj, TAdapter&& adapter) const;
};
class DeserializationStreamProxy
@@ -54,66 +44,46 @@ public:
DataStream* Stream;
template <class T>
- void Bytes(size_t byteCount, T* buffer) const
- {
- Stream->WriteBytes(byteCount, buffer);
- }
+ void Bytes(size_t byteCount, T* buffer) const;
template <class T>
- void Value(T& t) const
- {
- Stream->Read(t);
- }
+ void Value(T& t) const;
template <class T>
- void Object(T& obj) const
- {
- Stream->ReadObject(obj);
- }
+ void Object(T& obj) const;
template <class TObject, class TAdapter>
- void ObjectAdapted(TObject& obj, TAdapter& adapter) const
- {
- Stream->ReadObjectAdapted(obj, adapter);
- }
+ void ObjectAdapted(TObject& obj, TAdapter&& adapter) const;
};
-namespace DataStreamTraits {
-
-template <class T>
-concept HasMember = requires(T t)
-{
- t.ReadFromDataStream(std::declval<DataStream>());
- t.WriteToDataStream(std::declval<DataStream>());
-};
-
-template <class T>
-concept HasIOAdapterMember = requires(T t)
-{
- t.OperateIOProxy(std::declval<SerializationStreamProxy>());
- t.OperateIOProxy(std::declval<DeserializationStreamProxy>());
-};
-
-} // namespace DataStreamTraits
-
class DataStream
{
-public:
- enum Endianness
- {
- BigEndian,
- LittleEndian,
- };
-
private:
- Endianness mEndian;
+ // TODO customizable storage lik QIODevice
+ // TODO move read/write into separate classes, removing need of IOAdapters?
+ std::fstream mBackend;
+ std::endian mEndian;
public:
- DataStream();
+ DataStream(std::fstream stream);
~DataStream();
- Endianness GetEndianness() const;
- void SetEndianness(Endianness endianness);
+ std::endian GetEndianness() const;
+ void SetEndianness(std::endian endianness);
+
+ void WriteBytes(size_t byteCount, const std::byte* buffer);
+ void WriteBytes(size_t byteCount, const char* buffer);
+ void WriteBytes(size_t byteCount, const signed char* buffer);
+ void WriteBytes(size_t byteCount, const unsigned char* buffer);
+
+ template <class TIterator>
+ void WriteBytes(TIterator&& begin, TIterator&& end)
+ {
+ for (; begin != end; ++begin) {
+ uint8_t byte = *begin;
+ Write(byte);
+ }
+ }
void ReadBytes(size_t byteCount, std::byte* buffer);
void ReadBytes(size_t byteCount, char* buffer);
@@ -131,20 +101,6 @@ public:
}
}
- void WriteBytes(size_t byteCount, const std::byte* buffer);
- void WriteBytes(size_t byteCount, const char* buffer);
- void WriteBytes(size_t byteCount, const signed char* buffer);
- void WriteBytes(size_t byteCount, const unsigned char* buffer);
-
- template <class TIterator>
- void WriteBytes(TIterator&& begin, TIterator&& end)
- {
- for (; begin != end; ++begin) {
- uint8_t byte = *begin;
- Write(byte);
- }
- }
-
void Write(int8_t n);
void Write(int16_t n);
void Write(int32_t n);
@@ -172,13 +128,12 @@ public:
void Read(double& n);
template <class TObject>
- void ReadObject(TObject& obj)
+ void WriteObject(TObject& obj)
{
- using namespace DataStreamTraits;
- if constexpr (requires(TObject t) { t.ReadFromDataStream(std::declval<DataStream>()); }) {
- obj.ReadFromDataStream(*this);
- } else if constexpr (requires(TObject t) { t.OperateIOProxy(std::declval<DeserializationStreamProxy>()); }) {
- DeserializationStreamProxy adapter{ this };
+ if constexpr (requires(TObject t) { t.WriteToDataStream(std::declval<DataStream>()); }) {
+ obj.WriteToDataStream(*this);
+ } else if constexpr (requires(TObject t) { t.OperateIOProxy(std::declval<SerializationStreamProxy>()); }) {
+ SerializationStreamProxy adapter{ this };
obj.OperateIOProxy(adapter);
} else {
static_assert(false && sizeof(TObject), "This type does not have integration with DataStream.");
@@ -186,19 +141,18 @@ public:
}
template <class TObject, class TAdapter>
- void ReadObjectAdapted(TObject& obj, TAdapter& adapter)
+ void WriteObjectAdapted(TObject& obj, TAdapter&& adapter)
{
- adapter.ReadFromDataStream(*this, obj);
+ adapter.WriteToDataStream(*this, obj);
}
template <class TObject>
- void WriteObject(TObject& obj)
+ void ReadObject(TObject& obj)
{
- using namespace DataStreamTraits;
- if constexpr (requires(TObject t) { t.WriteToDataStream(std::declval<DataStream>()); }) {
- obj.WriteToDataStream(*this);
- } else if constexpr (requires(TObject t) { t.OperateIOProxy(std::declval<SerializationStreamProxy>()); }) {
- SerializationStreamProxy adapter{ this };
+ if constexpr (requires(TObject t) { t.ReadFromDataStream(std::declval<DataStream>()); }) {
+ obj.ReadFromDataStream(*this);
+ } else if constexpr (requires(TObject t) { t.OperateIOProxy(std::declval<DeserializationStreamProxy>()); }) {
+ DeserializationStreamProxy adapter{ this };
obj.OperateIOProxy(adapter);
} else {
static_assert(false && sizeof(TObject), "This type does not have integration with DataStream.");
@@ -206,8 +160,56 @@ public:
}
template <class TObject, class TAdapter>
- void WriteObjectAdapted(TObject& obj, TAdapter& adapter)
+ void ReadObjectAdapted(TObject& obj, TAdapter&& adapter)
{
- adapter.WriteToDataStream(*this, obj);
+ adapter.ReadFromDataStream(*this, obj);
}
};
+
+template <class T>
+void SerializationStreamProxy::Bytes(size_t byteCount, T* buffer) const
+{
+ Stream->WriteBytes(byteCount, buffer);
+}
+
+template <class T>
+void SerializationStreamProxy::Value(T t) const
+{
+ Stream->Write(t);
+}
+
+template <class T>
+void SerializationStreamProxy::Object(T& obj) const
+{
+ Stream->WriteObject(obj);
+}
+
+template <class TObject, class TAdapter>
+void SerializationStreamProxy::ObjectAdapted(TObject& obj, TAdapter&& adapter) const
+{
+ Stream->WriteObjectAdapted(obj, adapter);
+}
+
+template <class T>
+void DeserializationStreamProxy::Bytes(size_t byteCount, T* buffer) const
+{
+ Stream->WriteBytes(byteCount, buffer);
+}
+
+template <class T>
+void DeserializationStreamProxy::Value(T& t) const
+{
+ Stream->Read(t);
+}
+
+template <class T>
+void DeserializationStreamProxy::Object(T& obj) const
+{
+ Stream->ReadObject(obj);
+}
+
+template <class TObject, class TAdapter>
+void DeserializationStreamProxy::ObjectAdapted(TObject& obj, TAdapter&& adapter) const
+{
+ Stream->ReadObjectAdapted(obj, adapter);
+}