// ====================================================================== // \title PrimitiveF64ArrayAc.cpp // \author Generated by fpp-to-cpp // \brief cpp file for PrimitiveF64 array // ====================================================================== #include "Fw/Types/Assert.hpp" #include "PrimitiveF64ArrayAc.hpp" namespace M { // ---------------------------------------------------------------------- // Constructors // ---------------------------------------------------------------------- PrimitiveF64 :: PrimitiveF64() : Serializable() { *this = M::PrimitiveF64({1.0, 2.0, 3.0, 4.0, 5.0}); } PrimitiveF64 :: PrimitiveF64(const ElementType (&a)[SIZE]) : Serializable() { *this = a; } PrimitiveF64 :: PrimitiveF64(const ElementType& e) : Serializable() { *this = e; } PrimitiveF64 :: PrimitiveF64(const std::initializer_list& il) : Serializable() { *this = il; } PrimitiveF64 :: PrimitiveF64(const PrimitiveF64& obj) : Serializable() { *this = obj; } // ---------------------------------------------------------------------- // Operators // ---------------------------------------------------------------------- PrimitiveF64::ElementType& PrimitiveF64 :: operator[](const FwSizeType i) { FW_ASSERT(i < SIZE, static_cast(i), static_cast(SIZE)); return this->elements[i]; } const PrimitiveF64::ElementType& PrimitiveF64 :: operator[](const FwSizeType i) const { FW_ASSERT(i < SIZE, static_cast(i), static_cast(SIZE)); return this->elements[i]; } PrimitiveF64& PrimitiveF64 :: operator=(const PrimitiveF64& obj) { if (this != &obj) { for (FwSizeType index = 0; index < SIZE; index++) { this->elements[index] = obj.elements[index]; } } return *this; } PrimitiveF64& PrimitiveF64 :: operator=(const ElementType (&a)[SIZE]) { for (FwSizeType index = 0; index < SIZE; index++) { this->elements[index] = a[index]; } return *this; } PrimitiveF64& PrimitiveF64 :: operator=(const std::initializer_list& il) { // Since we are required to use C++11, this has to be a runtime check // In C++14, it can be a static check FW_ASSERT(il.size() == SIZE, static_cast(il.size()), static_cast(SIZE)); FwSizeType i = 0; for (const auto& e : il) { FW_ASSERT(i < SIZE, static_cast(i), static_cast(SIZE)); this->elements[i] = e; i++; } return *this; } PrimitiveF64& PrimitiveF64 :: operator=(const ElementType& e) { for (FwSizeType index = 0; index < SIZE; index++) { this->elements[index] = e; } return *this; } bool PrimitiveF64 :: operator==(const PrimitiveF64& obj) const { for (FwSizeType index = 0; index < SIZE; index++) { if (!((*this)[index] == obj[index])) { return false; } } return true; } bool PrimitiveF64 :: operator!=(const PrimitiveF64& obj) const { return !(*this == obj); } #ifdef BUILD_UT std::ostream& operator<<(std::ostream& os, const PrimitiveF64& obj) { Fw::String s; obj.toString(s); os << s; return os; } #endif // ---------------------------------------------------------------------- // Public member functions // ---------------------------------------------------------------------- Fw::SerializeStatus PrimitiveF64 :: serializeTo( Fw::SerializeBufferBase& buffer, Fw::Endianness mode ) const { Fw::SerializeStatus status = Fw::FW_SERIALIZE_OK; for (FwSizeType index = 0; index < SIZE; index++) { status = buffer.serializeFrom((*this)[index], mode); if (status != Fw::FW_SERIALIZE_OK) { return status; } } return status; } Fw::SerializeStatus PrimitiveF64 :: deserializeFrom( Fw::SerializeBufferBase& buffer, Fw::Endianness mode ) { Fw::SerializeStatus status = Fw::FW_SERIALIZE_OK; for (FwSizeType index = 0; index < SIZE; index++) { status = buffer.deserializeTo((*this)[index], mode); if (status != Fw::FW_SERIALIZE_OK) { return status; } } return status; } FwSizeType PrimitiveF64 :: serializedSize() const { return SERIALIZED_SIZE; } #if FW_SERIALIZABLE_TO_STRING void PrimitiveF64 :: toString(Fw::StringBase& sb) const { // Clear the output string sb = ""; // Array prefix if (sb.length() + 2 <= sb.maxLength()) { sb += "[ "; } else { return; } for (FwSizeType index = 0; index < SIZE; index++) { Fw::String tmp; tmp.format("%.5g", this->elements[index]); FwSizeType size = tmp.length() + (index > 0 ? 2 : 0); if ((size + sb.length()) <= sb.maxLength()) { if (index > 0) { sb += ", "; } sb += tmp; } else { break; } } // Array suffix if (sb.length() + 2 <= sb.maxLength()) { sb += " ]"; } } #endif }