fsfw/serialize/SerializeElement.h

64 lines
1.7 KiB
C
Raw Normal View History

2020-09-04 16:04:11 +02:00
#ifndef FSFW_SERIALIZE_SERIALIZEELEMENT_H_
#define FSFW_SERIALIZE_SERIALIZEELEMENT_H_
2020-08-28 18:33:29 +02:00
2020-09-04 16:04:11 +02:00
#include "SerializeAdapter.h"
2020-08-28 18:33:29 +02:00
#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().
2020-09-04 16:04:11 +02:00
* Serialization and Deserialization is then performed automatically in
2020-08-28 18:33:29 +02:00
* 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) {
}
2020-09-04 16:04:11 +02:00
2020-08-28 18:33:29 +02:00
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;
}
2020-09-04 16:04:11 +02:00
2020-08-28 18:33:29 +02:00
T* operator->() {
return &entry;
}
2020-09-04 16:04:11 +02:00
T entry;
2020-08-28 18:33:29 +02:00
};
2020-09-04 16:04:11 +02:00
#endif /* FSFW_SERIALIZE_SERIALIZEELEMENT_H_ */