fpp/compiler/tools/fpp-to-cpp/test/struct/EnumSerializableAc.ref.cpp
2025-11-16 13:40:21 -08:00

228 lines
4.0 KiB
C++
Vendored

// ======================================================================
// \title EnumSerializableAc.cpp
// \author Generated by fpp-to-cpp
// \brief cpp file for Enum struct
// ======================================================================
#include "EnumSerializableAc.hpp"
#include "Fw/Types/Assert.hpp"
// ----------------------------------------------------------------------
// Constructors
// ----------------------------------------------------------------------
Enum ::
Enum() :
Serializable(),
m_e{},
m_eArr{}
{
}
Enum ::
Enum(
M::E::T e,
const Type_of_eArr& eArr
) :
Serializable(),
m_e(e)
{
for (FwSizeType i = 0; i < 3; i++) {
this->m_eArr[i] = eArr[i];
}
}
Enum ::
Enum(const Enum& obj) :
Serializable(),
m_e(obj.m_e)
{
for (FwSizeType i = 0; i < 3; i++) {
this->m_eArr[i] = obj.m_eArr[i];
}
}
Enum ::
Enum(
M::E::T e,
M::E::T eArr
) :
Serializable(),
m_e(e)
{
for (FwSizeType i = 0; i < 3; i++) {
this->m_eArr[i] = eArr;
}
}
// ----------------------------------------------------------------------
// Operators
// ----------------------------------------------------------------------
Enum& Enum ::
operator=(const Enum& obj)
{
if (this == &obj) {
return *this;
}
set(obj.m_e, obj.m_eArr);
return *this;
}
bool Enum ::
operator==(const Enum& obj) const
{
if (this == &obj) { return true; }
// Compare non-array members
if (!(this->m_e == obj.m_e)) {
return false;
}
// Compare array members
for (FwSizeType i = 0; i < 3; i++) {
if (!(this->m_eArr[i] == obj.m_eArr[i])) {
return false;
}
}
return true;
}
bool Enum ::
operator!=(const Enum& obj) const
{
return !(*this == obj);
}
#ifdef BUILD_UT
std::ostream& operator<<(std::ostream& os, const Enum& obj) {
Fw::String s;
obj.toString(s);
os << s.toChar();
return os;
}
#endif
// ----------------------------------------------------------------------
// Member functions
// ----------------------------------------------------------------------
Fw::SerializeStatus Enum ::
serializeTo(
Fw::SerialBufferBase& buffer,
Fw::Endianness mode
) const
{
Fw::SerializeStatus status;
status = buffer.serializeFrom(this->m_e, mode);
if (status != Fw::FW_SERIALIZE_OK) {
return status;
}
for (FwSizeType i = 0; i < 3; i++) {
status = buffer.serializeFrom(this->m_eArr[i], mode);
if (status != Fw::FW_SERIALIZE_OK) {
return status;
}
}
return status;
}
Fw::SerializeStatus Enum ::
deserializeFrom(
Fw::SerialBufferBase& buffer,
Fw::Endianness mode
)
{
Fw::SerializeStatus status;
status = buffer.deserializeTo(this->m_e, mode);
if (status != Fw::FW_SERIALIZE_OK) {
return status;
}
for (FwSizeType i = 0; i < 3; i++) {
status = buffer.deserializeTo(this->m_eArr[i], mode);
if (status != Fw::FW_SERIALIZE_OK) {
return status;
}
}
return status;
}
FwSizeType Enum ::
serializedSize() const
{
FwSizeType size = 0;
size += M::E::SERIALIZED_SIZE;
size += M::E::SERIALIZED_SIZE * 3;
return size;
}
#if FW_SERIALIZABLE_TO_STRING
void Enum ::
toString(Fw::StringBase& sb) const
{
Fw::String tmp;
sb = "( ";
// Format e
sb += "e = ";
this->m_e.toString(tmp);
sb += tmp;
sb += ", ";
// Format eArr
sb += "eArr = ";
sb += "[ ";
for (FwSizeType i = 0; i < 3; i++) {
this->m_eArr[i].toString(tmp);
if (i > 0) {
sb += ", ";
}
sb += tmp;
}
sb += " ]";
sb += " )";
}
#endif
// ----------------------------------------------------------------------
// Setter functions
// ----------------------------------------------------------------------
void Enum ::
set(
M::E::T e,
const Type_of_eArr& eArr
)
{
this->m_e = e;
for (FwSizeType i = 0; i < 3; i++) {
this->m_eArr[i] = eArr[i];
}
}
void Enum ::
set_e(M::E::T e)
{
this->m_e = e;
}
void Enum ::
set_eArr(const Type_of_eArr& eArr)
{
for (FwSizeType i = 0; i < 3; i++) {
this->m_eArr[i] = eArr[i];
}
}