64 lines
1.7 KiB
C++
64 lines
1.7 KiB
C++
#ifndef FSFW_SERIALIZE_SERIALIZEELEMENT_H_
|
|
#define FSFW_SERIALIZE_SERIALIZEELEMENT_H_
|
|
|
|
#include "SerializeAdapter.h"
|
|
#include "../container/SinglyLinkedList.h"
|
|
#include <utility>
|
|
|
|
/**
|
|
* @brief This class is used to mark datatypes for serialization with the
|
|
* SerialLinkedListAdapter
|
|
* @details
|
|
* Used by declaring any arbitrary datatype with SerializeElement<T> myVariable,
|
|
* inside a SerialLinkedListAdapter implementation and setting the sequence
|
|
* of objects with setNext() and setStart().
|
|
* Serialization and Deserialization is then performed automatically in
|
|
* specified sequence order.
|
|
* @ingroup serialize
|
|
*/
|
|
template<typename T>
|
|
class SerializeElement: public SerializeIF, public LinkedElement<SerializeIF> {
|
|
public:
|
|
template<typename ... Args>
|
|
SerializeElement(Args ... args) :
|
|
LinkedElement<SerializeIF>(this), entry(std::forward<Args>(args)...) {
|
|
|
|
}
|
|
SerializeElement() :
|
|
LinkedElement<SerializeIF>(this) {
|
|
}
|
|
|
|
ReturnValue_t serialize(uint8_t **buffer, size_t *size, size_t maxSize,
|
|
Endianness streamEndianness) const override {
|
|
return SerializeAdapter::serialize(&entry, buffer, size, maxSize,
|
|
streamEndianness);
|
|
}
|
|
|
|
size_t getSerializedSize() const override {
|
|
return SerializeAdapter::getSerializedSize(&entry);
|
|
}
|
|
|
|
virtual ReturnValue_t deSerialize(const uint8_t **buffer, size_t *size,
|
|
Endianness streamEndianness) override {
|
|
return SerializeAdapter::deSerialize(&entry, buffer, size,
|
|
streamEndianness);
|
|
}
|
|
|
|
operator T() {
|
|
return entry;
|
|
}
|
|
|
|
SerializeElement<T>& operator=(T newValue) {
|
|
entry = newValue;
|
|
return *this;
|
|
}
|
|
|
|
T* operator->() {
|
|
return &entry;
|
|
}
|
|
|
|
T entry = 0;
|
|
};
|
|
|
|
#endif /* FSFW_SERIALIZE_SERIALIZEELEMENT_H_ */
|