#pragma once #include #include #include #define DRONECAN_REMOTEID_LOCATION_MAX_SIZE 58 #define DRONECAN_REMOTEID_LOCATION_SIGNATURE (0xEAA3A2C5BCB14CAAULL) #define DRONECAN_REMOTEID_LOCATION_ID 20031 #define DRONECAN_REMOTEID_LOCATION_ODID_STATUS_UNDECLARED 0 #define DRONECAN_REMOTEID_LOCATION_ODID_STATUS_GROUND 1 #define DRONECAN_REMOTEID_LOCATION_ODID_STATUS_AIRBORNE 2 #define DRONECAN_REMOTEID_LOCATION_ODID_STATUS_EMERGENCY 3 #define DRONECAN_REMOTEID_LOCATION_ODID_HEIGHT_REF_OVER_TAKEOFF 0 #define DRONECAN_REMOTEID_LOCATION_ODID_HEIGHT_REF_OVER_GROUND 1 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_UNKNOWN 0 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_10NM 1 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_4NM 2 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_2NM 3 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_1NM 4 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_0_5NM 5 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_0_3NM 6 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_0_1NM 7 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_0_05NM 8 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_30_METER 9 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_10_METER 10 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_3_METER 11 #define DRONECAN_REMOTEID_LOCATION_ODID_HOR_ACC_1_METER 12 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_UNKNOWN 0 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_150_METER 1 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_45_METER 2 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_25_METER 3 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_10_METER 4 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_3_METER 5 #define DRONECAN_REMOTEID_LOCATION_ODID_VER_ACC_1_METER 6 #define DRONECAN_REMOTEID_LOCATION_ODID_SPEED_ACC_UNKNOWN 0 #define DRONECAN_REMOTEID_LOCATION_ODID_SPEED_ACC_10_METERS_PER_SECOND 1 #define DRONECAN_REMOTEID_LOCATION_ODID_SPEED_ACC_3_METERS_PER_SECOND 2 #define DRONECAN_REMOTEID_LOCATION_ODID_SPEED_ACC_1_METERS_PER_SECOND 3 #define DRONECAN_REMOTEID_LOCATION_ODID_SPEED_ACC_0_3_METERS_PER_SECOND 4 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_1_SECOND 1 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_2_SECOND 2 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_3_SECOND 3 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_4_SECOND 4 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_5_SECOND 5 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_6_SECOND 6 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_7_SECOND 7 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_8_SECOND 8 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_0_9_SECOND 9 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_1_0_SECOND 10 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_1_1_SECOND 11 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_1_2_SECOND 12 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_1_3_SECOND 13 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_1_4_SECOND 14 #define DRONECAN_REMOTEID_LOCATION_ODID_TIME_ACC_1_5_SECOND 15 #if defined(__cplusplus) && defined(DRONECAN_CXX_WRAPPERS) class dronecan_remoteid_Location_cxx_iface; #endif struct dronecan_remoteid_Location { #if defined(__cplusplus) && defined(DRONECAN_CXX_WRAPPERS) using cxx_iface = dronecan_remoteid_Location_cxx_iface; #endif struct { uint8_t len; uint8_t data[20]; }id_or_mac; uint8_t status; uint16_t direction; uint16_t speed_horizontal; int16_t speed_vertical; int32_t latitude; int32_t longitude; float altitude_barometric; float altitude_geodetic; uint8_t height_reference; float height; uint8_t horizontal_accuracy; uint8_t vertical_accuracy; uint8_t barometer_accuracy; uint8_t speed_accuracy; float timestamp; uint8_t timestamp_accuracy; }; #ifdef __cplusplus extern "C" { #endif uint32_t dronecan_remoteid_Location_encode(struct dronecan_remoteid_Location* msg, uint8_t* buffer #if CANARD_ENABLE_TAO_OPTION , bool tao #endif ); bool dronecan_remoteid_Location_decode(const CanardRxTransfer* transfer, struct dronecan_remoteid_Location* msg); #if defined(CANARD_DSDLC_INTERNAL) static inline void _dronecan_remoteid_Location_encode(uint8_t* buffer, uint32_t* bit_ofs, struct dronecan_remoteid_Location* msg, bool tao); static inline bool _dronecan_remoteid_Location_decode(const CanardRxTransfer* transfer, uint32_t* bit_ofs, struct dronecan_remoteid_Location* msg, bool tao); void _dronecan_remoteid_Location_encode(uint8_t* buffer, uint32_t* bit_ofs, struct dronecan_remoteid_Location* msg, bool tao) { (void)buffer; (void)bit_ofs; (void)msg; (void)tao; #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wtype-limits" const uint8_t id_or_mac_len = msg->id_or_mac.len > 20 ? 20 : msg->id_or_mac.len; #pragma GCC diagnostic pop canardEncodeScalar(buffer, *bit_ofs, 5, &id_or_mac_len); *bit_ofs += 5; for (size_t i=0; i < id_or_mac_len; i++) { canardEncodeScalar(buffer, *bit_ofs, 8, &msg->id_or_mac.data[i]); *bit_ofs += 8; } canardEncodeScalar(buffer, *bit_ofs, 8, &msg->status); *bit_ofs += 8; canardEncodeScalar(buffer, *bit_ofs, 16, &msg->direction); *bit_ofs += 16; canardEncodeScalar(buffer, *bit_ofs, 16, &msg->speed_horizontal); *bit_ofs += 16; canardEncodeScalar(buffer, *bit_ofs, 16, &msg->speed_vertical); *bit_ofs += 16; canardEncodeScalar(buffer, *bit_ofs, 32, &msg->latitude); *bit_ofs += 32; canardEncodeScalar(buffer, *bit_ofs, 32, &msg->longitude); *bit_ofs += 32; canardEncodeScalar(buffer, *bit_ofs, 32, &msg->altitude_barometric); *bit_ofs += 32; canardEncodeScalar(buffer, *bit_ofs, 32, &msg->altitude_geodetic); *bit_ofs += 32; canardEncodeScalar(buffer, *bit_ofs, 8, &msg->height_reference); *bit_ofs += 8; canardEncodeScalar(buffer, *bit_ofs, 32, &msg->height); *bit_ofs += 32; canardEncodeScalar(buffer, *bit_ofs, 8, &msg->horizontal_accuracy); *bit_ofs += 8; canardEncodeScalar(buffer, *bit_ofs, 8, &msg->vertical_accuracy); *bit_ofs += 8; canardEncodeScalar(buffer, *bit_ofs, 8, &msg->barometer_accuracy); *bit_ofs += 8; canardEncodeScalar(buffer, *bit_ofs, 8, &msg->speed_accuracy); *bit_ofs += 8; canardEncodeScalar(buffer, *bit_ofs, 32, &msg->timestamp); *bit_ofs += 32; canardEncodeScalar(buffer, *bit_ofs, 8, &msg->timestamp_accuracy); *bit_ofs += 8; } /* decode dronecan_remoteid_Location, return true on failure, false on success */ bool _dronecan_remoteid_Location_decode(const CanardRxTransfer* transfer, uint32_t* bit_ofs, struct dronecan_remoteid_Location* msg, bool tao) { (void)transfer; (void)bit_ofs; (void)msg; (void)tao; canardDecodeScalar(transfer, *bit_ofs, 5, false, &msg->id_or_mac.len); *bit_ofs += 5; #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wtype-limits" if (msg->id_or_mac.len > 20) { return true; /* invalid value */ } #pragma GCC diagnostic pop for (size_t i=0; i < msg->id_or_mac.len; i++) { canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->id_or_mac.data[i]); *bit_ofs += 8; } canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->status); *bit_ofs += 8; canardDecodeScalar(transfer, *bit_ofs, 16, false, &msg->direction); *bit_ofs += 16; canardDecodeScalar(transfer, *bit_ofs, 16, false, &msg->speed_horizontal); *bit_ofs += 16; canardDecodeScalar(transfer, *bit_ofs, 16, true, &msg->speed_vertical); *bit_ofs += 16; canardDecodeScalar(transfer, *bit_ofs, 32, true, &msg->latitude); *bit_ofs += 32; canardDecodeScalar(transfer, *bit_ofs, 32, true, &msg->longitude); *bit_ofs += 32; canardDecodeScalar(transfer, *bit_ofs, 32, true, &msg->altitude_barometric); *bit_ofs += 32; canardDecodeScalar(transfer, *bit_ofs, 32, true, &msg->altitude_geodetic); *bit_ofs += 32; canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->height_reference); *bit_ofs += 8; canardDecodeScalar(transfer, *bit_ofs, 32, true, &msg->height); *bit_ofs += 32; canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->horizontal_accuracy); *bit_ofs += 8; canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->vertical_accuracy); *bit_ofs += 8; canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->barometer_accuracy); *bit_ofs += 8; canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->speed_accuracy); *bit_ofs += 8; canardDecodeScalar(transfer, *bit_ofs, 32, true, &msg->timestamp); *bit_ofs += 32; canardDecodeScalar(transfer, *bit_ofs, 8, false, &msg->timestamp_accuracy); *bit_ofs += 8; return false; /* success */ } #endif #ifdef CANARD_DSDLC_TEST_BUILD struct dronecan_remoteid_Location sample_dronecan_remoteid_Location_msg(void); #endif #ifdef __cplusplus } // extern "C" #ifdef DRONECAN_CXX_WRAPPERS #include BROADCAST_MESSAGE_CXX_IFACE(dronecan_remoteid_Location, DRONECAN_REMOTEID_LOCATION_ID, DRONECAN_REMOTEID_LOCATION_SIGNATURE, DRONECAN_REMOTEID_LOCATION_MAX_SIZE); #endif #endif