mirror of
https://github.com/nasa/fpp.git
synced 2025-12-12 15:59:33 -06:00
238 lines
4.6 KiB
C++
238 lines
4.6 KiB
C++
// ======================================================================
|
|
// \title StringArraySerializableAc.cpp
|
|
// \author Generated by fpp-to-cpp
|
|
// \brief cpp file for StringArray struct
|
|
// ======================================================================
|
|
|
|
#include <cstdio>
|
|
#include <cstring>
|
|
|
|
#include "Fw/Types/Assert.hpp"
|
|
#include "Fw/Types/StringUtils.hpp"
|
|
#include "StringArraySerializableAc.hpp"
|
|
|
|
// ----------------------------------------------------------------------
|
|
// Constructors
|
|
// ----------------------------------------------------------------------
|
|
|
|
StringArray ::
|
|
StringArray() :
|
|
Serializable(),
|
|
m_s1(Fw::String(""))
|
|
{
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
this->m_s2[i] = Fw::String("");
|
|
}
|
|
}
|
|
|
|
StringArray ::
|
|
StringArray(
|
|
const Fw::StringBase& s1,
|
|
const Type_of_s2& s2
|
|
) :
|
|
Serializable(),
|
|
m_s1(s1)
|
|
{
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
this->m_s2[i] = s2[i];
|
|
}
|
|
}
|
|
|
|
StringArray ::
|
|
StringArray(const StringArray& obj) :
|
|
Serializable(),
|
|
m_s1(obj.m_s1)
|
|
{
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
this->m_s2[i] = obj.m_s2[i];
|
|
}
|
|
}
|
|
|
|
StringArray ::
|
|
StringArray(
|
|
const Fw::StringBase& s1,
|
|
const Fw::StringBase& s2
|
|
) :
|
|
Serializable(),
|
|
m_s1(s1)
|
|
{
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
this->m_s2[i] = s2;
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------
|
|
// Operators
|
|
// ----------------------------------------------------------------------
|
|
|
|
StringArray& StringArray ::
|
|
operator=(const StringArray& obj)
|
|
{
|
|
if (this == &obj) {
|
|
return *this;
|
|
}
|
|
|
|
set(obj.m_s1, obj.m_s2);
|
|
return *this;
|
|
}
|
|
|
|
bool StringArray ::
|
|
operator==(const StringArray& obj) const
|
|
{
|
|
// Compare non-array members
|
|
if (!(this->m_s1 == obj.m_s1)) {
|
|
return false;
|
|
}
|
|
|
|
// Compare array members
|
|
if (!(this->m_s2 == obj.m_s2)) {
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
if (!(this->m_s2[i] == obj.m_s2[i])) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
bool StringArray ::
|
|
operator!=(const StringArray& obj) const
|
|
{
|
|
return !(*this == obj);
|
|
}
|
|
|
|
#ifdef BUILD_UT
|
|
|
|
std::ostream& operator<<(std::ostream& os, const StringArray& obj) {
|
|
Fw::String s;
|
|
obj.toString(s);
|
|
os << s.toChar();
|
|
return os;
|
|
}
|
|
|
|
#endif
|
|
|
|
// ----------------------------------------------------------------------
|
|
// Member functions
|
|
// ----------------------------------------------------------------------
|
|
|
|
Fw::SerializeStatus StringArray ::
|
|
serialize(Fw::SerializeBufferBase& buffer) const
|
|
{
|
|
Fw::SerializeStatus status;
|
|
|
|
status = buffer.serialize(this->m_s1);
|
|
if (status != Fw::FW_SERIALIZE_OK) {
|
|
return status;
|
|
}
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
status = buffer.serialize(this->m_s2[i]);
|
|
if (status != Fw::FW_SERIALIZE_OK) {
|
|
return status;
|
|
}
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
Fw::SerializeStatus StringArray ::
|
|
deserialize(Fw::SerializeBufferBase& buffer)
|
|
{
|
|
Fw::SerializeStatus status;
|
|
|
|
status = buffer.deserialize(this->m_s1);
|
|
if (status != Fw::FW_SERIALIZE_OK) {
|
|
return status;
|
|
}
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
status = buffer.deserialize(this->m_s2[i]);
|
|
if (status != Fw::FW_SERIALIZE_OK) {
|
|
return status;
|
|
}
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
#if FW_SERIALIZABLE_TO_STRING
|
|
|
|
void StringArray ::
|
|
toString(Fw::StringBase& sb) const
|
|
{
|
|
static const char* formatString =
|
|
"( "
|
|
"s1 = %s, "
|
|
"s2 = [ %s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s, "
|
|
"%s ]"
|
|
" )";
|
|
|
|
sb.format(
|
|
formatString,
|
|
this->m_s1.toChar(),
|
|
this->m_s2[0].toChar(),
|
|
this->m_s2[1].toChar(),
|
|
this->m_s2[2].toChar(),
|
|
this->m_s2[3].toChar(),
|
|
this->m_s2[4].toChar(),
|
|
this->m_s2[5].toChar(),
|
|
this->m_s2[6].toChar(),
|
|
this->m_s2[7].toChar(),
|
|
this->m_s2[8].toChar(),
|
|
this->m_s2[9].toChar(),
|
|
this->m_s2[10].toChar(),
|
|
this->m_s2[11].toChar(),
|
|
this->m_s2[12].toChar(),
|
|
this->m_s2[13].toChar(),
|
|
this->m_s2[14].toChar(),
|
|
this->m_s2[15].toChar()
|
|
);
|
|
}
|
|
|
|
#endif
|
|
|
|
// ----------------------------------------------------------------------
|
|
// Setter functions
|
|
// ----------------------------------------------------------------------
|
|
|
|
void StringArray ::
|
|
set(
|
|
const Fw::StringBase& s1,
|
|
const Type_of_s2& s2
|
|
)
|
|
{
|
|
this->m_s1 = s1;
|
|
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
this->m_s2[i] = s2[i];
|
|
}
|
|
}
|
|
|
|
void StringArray ::
|
|
sets1(const Fw::StringBase& s1)
|
|
{
|
|
this->m_s1 = s1;
|
|
}
|
|
|
|
void StringArray ::
|
|
sets2(const Type_of_s2& s2)
|
|
{
|
|
for (FwSizeType i = 0; i < 16; i++) {
|
|
this->m_s2[i] = s2[i];
|
|
}
|
|
}
|