fpp/compiler/tools/fpp-to-cpp/test/enum/ImplicitEnumAc.ref.cpp
2022-06-15 16:38:26 -07:00

140 lines
2.6 KiB
C++

// ======================================================================
// \title ImplicitEnumAc.cpp
// \author Generated by fpp-to-cpp
// \brief cpp file for Implicit enum
// ======================================================================
#include <cstring>
#include <limits>
#include "Fw/Types/Assert.hpp"
#include "ImplicitEnumAc.hpp"
namespace M {
// ----------------------------------------------------------------------
// Constructors
// ----------------------------------------------------------------------
Implicit ::
Implicit()
{
this->e = X;
}
Implicit ::
Implicit(const T e)
{
this->e = e;
}
Implicit ::
Implicit(const Implicit& obj)
{
this->e = obj.e;
}
// ----------------------------------------------------------------------
// Operators
// ----------------------------------------------------------------------
Implicit& Implicit ::
operator=(const Implicit& obj)
{
this->e = obj.e;
return *this;
}
Implicit& Implicit ::
operator=(T e)
{
this->e = e;
return *this;
}
Implicit ::
operator t() const
{
return this->e;
}
bool Implicit ::
operator==(const Implicit& obj) const
{
return this->e == obj.e;
}
bool Implicit ::
operator!=(const Implicit& obj) const
{
return !(*this == obj);
}
#ifdef BUILD_UT
std::ostream& operator<<(std::ostream& os, const Implicit& obj) {
Fw::String s;
obj.toString(s);
os << s;
return os;
}
#endif
// ----------------------------------------------------------------------
// Member functions
// ----------------------------------------------------------------------
bool Implicit ::
isValid() const
{
return ((e >= X) && (e <= Y));
}
Fw::SerializeStatus Implicit ::
serialize(Fw::SerializeBufferBase& buffer) const
{
const Fw::SerializeStatus status = buffer.serialize(
static_cast<SerialType>(this->e)
);
return status;
}
Fw::SerializeStatus Implicit ::
deserialize(Fw::SerializeBufferBase& buffer)
{
SerialType es;
Fw::SerializeStatus status = buffer.deserialize(es);
if (status == Fw::FW_SERIALIZE_OK) {
this->e = static_cast<T>(es);
if (!this->isValid()) {
status = Fw::FW_DESERIALIZE_FORMAT_ERROR;
}
}
return status;
}
#if FW_SERIALIZABLE_TO_STRING || BUILD_UT
void Implicit ::
toString(Fw::StringBase& sb) const
{
Fw::String s;
switch (e) {
case X:
s = "X";
break;
case Y:
s = "Y";
break;
default:
s = "[invalid]";
break;
}
sb.format("%s (%d)", s.toChar(), e);
}
#endif
}