QGroundControl
Ground Control Station for MAVLink Drones
Loading...
Searching...
No Matches
RequestMessageCoordinator.h
Go to the documentation of this file.
1#pragma once
2
3#include <QtCore/QElapsedTimer>
4#include <QtCore/QList>
5#include <QtCore/QMap>
6#include <QtCore/QObject>
7#include <QtCore/QPointer>
8
9#include "VehicleTypes.h"
10
11class MavCommandQueue;
12class Vehicle;
13
18
19class RequestMessageCoordinator : public QObject, public VehicleTypes
20{
21 Q_OBJECT
22
23public:
24 RequestMessageCoordinator(Vehicle* vehicle, MavCommandQueue* commandQueue);
26
30 void requestMessage(RequestMessageResultHandler resultHandler, void* resultHandlerData,
31 int compId, int messageId,
32 float param1 = 0.0f, float param2 = 0.0f, float param3 = 0.0f, float param4 = 0.0f, float param5 = 0.0f);
33
36 void handleReceivedMessage(const mavlink_message_t& message);
37
39 void stop();
40
42
43private:
44 typedef struct RequestMessageInfo {
45 QPointer<Vehicle> vehicle; // QPointer automatically becomes null when Vehicle is destroyed
46 RequestMessageCoordinator* coordinator = nullptr; // Back-pointer so the static ack handler can reach the instance.
47 int compId = 0;
48 int msgId = 0;
49 float param1 = 0.0f;
50 float param2 = 0.0f;
51 float param3 = 0.0f;
52 float param4 = 0.0f;
53 float param5 = 0.0f;
54 RequestMessageResultHandler resultHandler = nullptr;
55 void* resultHandlerData = nullptr;
56 bool commandAckReceived = false; // We keep track of the ack/message being received since the order in which this will come in is random
57 bool messageReceived = false; // We only delete the allocated RequestMessageInfo when both the message is received and we get the ack
58 QElapsedTimer messageWaitElapsedTimer; // Elapsed time since we started waiting message to show up
59 mavlink_message_t message;
60 } RequestMessageInfo_t;
61
62 void _removeInfo(int compId, int msgId);
63 bool _duplicate(int compId, int msgId) const;
64 void _sendNow(RequestMessageInfo_t* info);
65 void _sendNextFromQueue(int compId);
66
67 static void _cmdResultHandler(void* resultHandlerData, int compId, const mavlink_command_ack_t& ack, MavCmdResultFailureCode_t failureCode);
68
69 Vehicle* _vehicle = nullptr;
70 MavCommandQueue* _commandQueue = nullptr;
71
72 QMap<int /* compId */, QMap<int /* msgId */, RequestMessageInfo_t*>> _infoMap; // Active requests awaiting response
73 QMap<int /* compId */, QList<RequestMessageInfo_t*>> _queueMap; // Per-component queue waiting for active request to finish
74};
struct __mavlink_message mavlink_message_t
struct __mavlink_command_ack_t mavlink_command_ack_t
Owns the COMMAND_LONG / COMMAND_INT send/retry/ack pipeline for a single Vehicle.
Coordinates MAV_CMD_REQUEST_MESSAGE workflows: per-component queueing, ack/message correlation,...
void handleReceivedMessage(const mavlink_message_t &message)
static QString failureCodeToString(RequestMessageResultHandlerFailureCode_t failureCode)
void requestMessage(RequestMessageResultHandler resultHandler, void *resultHandlerData, int compId, int messageId, float param1=0.0f, float param2=0.0f, float param3=0.0f, float param4=0.0f, float param5=0.0f)
void stop()
Clear pending state without firing callbacks (used during vehicle shutdown).
void(* RequestMessageResultHandler)(void *resultHandlerData, MAV_RESULT commandResult, RequestMessageResultHandlerFailureCode_t failureCode, const mavlink_message_t &message)
Callback for requestMessage — delivered when the ack/message pair resolves or a failure occurs.
RequestMessageResultHandlerFailureCode_t