dronecan.remoteid.ArmStatus.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #pragma once
  2. #include <stdbool.h>
  3. #include <stdint.h>
  4. #include <canard.h>
  5. #define DRONECAN_REMOTEID_ARMSTATUS_MAX_SIZE 52
  6. #define DRONECAN_REMOTEID_ARMSTATUS_SIGNATURE (0xFEDF72CCF06F3BDDULL)
  7. #define DRONECAN_REMOTEID_ARMSTATUS_ID 20035
  8. #define DRONECAN_REMOTEID_ARMSTATUS_ODID_ARM_STATUS_GOOD_TO_ARM 0
  9. #define DRONECAN_REMOTEID_ARMSTATUS_ODID_ARM_STATUS_FAIL_GENERIC 1
  10. #if defined(__cplusplus) && defined(DRONECAN_CXX_WRAPPERS)
  11. class dronecan_remoteid_ArmStatus_cxx_iface;
  12. #endif
  13. struct dronecan_remoteid_ArmStatus {
  14. #if defined(__cplusplus) && defined(DRONECAN_CXX_WRAPPERS)
  15. using cxx_iface = dronecan_remoteid_ArmStatus_cxx_iface;
  16. #endif
  17. uint8_t status;
  18. struct { uint8_t len; uint8_t data[50]; }error;
  19. };
  20. #ifdef __cplusplus
  21. extern "C"
  22. {
  23. #endif
  24. uint32_t dronecan_remoteid_ArmStatus_encode(struct dronecan_remoteid_ArmStatus* msg, uint8_t* buffer
  25. #if CANARD_ENABLE_TAO_OPTION
  26. , bool tao
  27. #endif
  28. );
  29. bool dronecan_remoteid_ArmStatus_decode(const CanardRxTransfer* transfer, struct dronecan_remoteid_ArmStatus* msg);
  30. #if defined(CANARD_DSDLC_INTERNAL)
  31. static inline void _dronecan_remoteid_ArmStatus_encode(uint8_t* buffer, uint32_t* bit_ofs, struct dronecan_remoteid_ArmStatus* msg, bool tao);
  32. static inline bool _dronecan_remoteid_ArmStatus_decode(const CanardRxTransfer* transfer, uint32_t* bit_ofs, struct dronecan_remoteid_ArmStatus* msg, bool tao);
  33. void _dronecan_remoteid_ArmStatus_encode(uint8_t* buffer, uint32_t* bit_ofs, struct dronecan_remoteid_ArmStatus* msg, bool tao) {
  34. (void)buffer;
  35. (void)bit_ofs;
  36. (void)msg;
  37. (void)tao;
  38. canardEncodeScalar(buffer, *bit_ofs, 8, &msg->status);
  39. *bit_ofs += 8;
  40. #pragma GCC diagnostic push
  41. #pragma GCC diagnostic ignored "-Wtype-limits"
  42. const uint8_t error_len = msg->error.len > 50 ? 50 : msg->error.len;
  43. #pragma GCC diagnostic pop
  44. if (!tao) {
  45. canardEncodeScalar(buffer, *bit_ofs, 6, &error_len);
  46. *bit_ofs += 6;
  47. }
  48. for (size_t i=0; i < error_len; i++) {
  49. canardEncodeScalar(buffer, *bit_ofs, 8, &msg->error.data[i]);
  50. *bit_ofs += 8;
  51. }
  52. }
  53. /*
  54. decode dronecan_remoteid_ArmStatus, return true on failure, false on success
  55. */
  56. bool _dronecan_remoteid_ArmStatus_decode(const CanardRxTransfer* transfer, uint32_t* bit_ofs, struct dronecan_remoteid_ArmStatus* msg, bool tao) {
  57. (void)transfer;
  58. (void)bit_ofs;
  59. (void)msg;
  60. (void)tao;
  61. canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->status);
  62. *bit_ofs += 8;
  63. if (!tao) {
  64. canardDecodeScalar(transfer, *bit_ofs, 6, false, &msg->error.len);
  65. *bit_ofs += 6;
  66. } else {
  67. msg->error.len = ((transfer->payload_len*8)-*bit_ofs)/8;
  68. }
  69. #pragma GCC diagnostic push
  70. #pragma GCC diagnostic ignored "-Wtype-limits"
  71. if (msg->error.len > 50) {
  72. return true; /* invalid value */
  73. }
  74. #pragma GCC diagnostic pop
  75. for (size_t i=0; i < msg->error.len; i++) {
  76. canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->error.data[i]);
  77. *bit_ofs += 8;
  78. }
  79. return false; /* success */
  80. }
  81. #endif
  82. #ifdef CANARD_DSDLC_TEST_BUILD
  83. struct dronecan_remoteid_ArmStatus sample_dronecan_remoteid_ArmStatus_msg(void);
  84. #endif
  85. #ifdef __cplusplus
  86. } // extern "C"
  87. #ifdef DRONECAN_CXX_WRAPPERS
  88. #include <canard/cxx_wrappers.h>
  89. BROADCAST_MESSAGE_CXX_IFACE(dronecan_remoteid_ArmStatus, DRONECAN_REMOTEID_ARMSTATUS_ID, DRONECAN_REMOTEID_ARMSTATUS_SIGNATURE, DRONECAN_REMOTEID_ARMSTATUS_MAX_SIZE);
  90. #endif
  91. #endif