// ====================================================================== // \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]; } }