F´ Flight Software - C/C++ Documentation
A framework for building embedded system applications to NASA flight quality standards.
I2cStatusEnumAc.cpp
Go to the documentation of this file.
1 // ======================================================================
2 // \title I2cStatusEnumAc.cpp
3 // \author Generated by fpp-to-cpp
4 // \brief cpp file for I2cStatus enum
5 // ======================================================================
6 
7 #include <cstring>
8 #include <limits>
9 
10 #include "Fw/Types/Assert.hpp"
12 
13 namespace Drv {
14 
15  // ----------------------------------------------------------------------
16  // Operators
17  // ----------------------------------------------------------------------
18 
19  I2cStatus& I2cStatus ::
20  operator=(const I2cStatus& obj)
21  {
22  this->e = obj.e;
23  return *this;
24  }
25 
28  {
29  this->e = e1;
30  return *this;
31  }
32 
33 #ifdef BUILD_UT
34 
35  std::ostream& operator<<(std::ostream& os, const I2cStatus& obj) {
36  Fw::String s;
37  obj.toString(s);
38  os << s;
39  return os;
40  }
41 
42 #endif
43 
44  // ----------------------------------------------------------------------
45  // Member functions
46  // ----------------------------------------------------------------------
47 
48  bool I2cStatus ::
49  isValid() const
50  {
51  return ((e >= I2C_OK) && (e <= I2C_OTHER_ERR));
52  }
53 
56  Fw::SerialBufferBase& buffer,
57  Fw::Endianness mode
58  ) const
59  {
60  const Fw::SerializeStatus status = buffer.serializeFrom(
61  static_cast<SerialType>(this->e),
62  mode
63  );
64  return status;
65  }
66 
69  Fw::SerialBufferBase& buffer,
70  Fw::Endianness mode
71  )
72  {
73  SerialType es;
74  Fw::SerializeStatus status = buffer.deserializeTo(es, mode);
75  if (status == Fw::FW_SERIALIZE_OK) {
76  this->e = static_cast<T>(es);
77  if (!this->isValid()) {
79  }
80  }
81  return status;
82  }
83 
84 #if FW_SERIALIZABLE_TO_STRING
85 
86  void I2cStatus ::
87  toString(Fw::StringBase& sb) const
88  {
89  Fw::String s;
90  switch (e) {
91  case I2C_OK:
92  s = "I2C_OK";
93  break;
94  case I2C_ADDRESS_ERR:
95  s = "I2C_ADDRESS_ERR";
96  break;
97  case I2C_WRITE_ERR:
98  s = "I2C_WRITE_ERR";
99  break;
100  case I2C_READ_ERR:
101  s = "I2C_READ_ERR";
102  break;
103  case I2C_OPEN_ERR:
104  s = "I2C_OPEN_ERR";
105  break;
106  case I2C_OTHER_ERR:
107  s = "I2C_OTHER_ERR";
108  break;
109  default:
110  s = "[invalid]";
111  break;
112  }
113  sb.format("%s (%" PRIu8 ")", s.toChar(), e);
114  }
115 
116 #elif FW_ENABLE_TEXT_LOGGING
117 
118  void I2cStatus ::
119  toString(Fw::StringBase& sb) const
120  {
121  sb.format("%" PRIu8 "", e);
122  }
123 
124 #endif
125 
126 }
Serialization/Deserialization operation was successful.
const char * toChar() const
Convert to a C-style char*.
Definition: String.hpp:50
T
The raw enum type.
Deserialization data had incorrect values (unexpected data types)
virtual SerializeStatus serializeFrom(U8 val, Endianness mode=Endianness::BIG)=0
Serialize an 8-bit unsigned integer value.
SerializeStatus
forward declaration for string
virtual SerializeStatus deserializeTo(U8 &val, Endianness mode=Endianness::BIG)=0
Deserialize an 8-bit unsigned integer value.
bool isValid() const
Check raw enum value for validity.
Fw::SerializeStatus serializeTo(Fw::SerialBufferBase &buffer, Fw::Endianness mode=Fw::Endianness::BIG) const
Serialize raw enum value to SerialType.
Fw::SerializeStatus deserializeFrom(Fw::SerialBufferBase &buffer, Fw::Endianness mode=Fw::Endianness::BIG)
Deserialize raw enum value from SerialType.
I2cStatus & operator=(const I2cStatus &obj)
Copy assignment operator (object)
T e
The raw enum value.
U8 SerialType
The serial representation type.
FormatStatus format(const CHAR *formatString,...)
write formatted string to buffer
Definition: StringBase.cpp:39
Other errors that don&#39;t fit.
Endianness
I2C driver failed to open device.
Transaction okay.