mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 00:28:30 -04:00
57528b94cf
Also terminate uploads if any error occurs fetching items
69 lines
2.6 KiB
C++
69 lines
2.6 KiB
C++
#pragma once
|
|
|
|
#include "MissionItemProtocol.h"
|
|
|
|
class MissionItemProtocol_Waypoints : public MissionItemProtocol {
|
|
public:
|
|
MissionItemProtocol_Waypoints(class AP_Mission &_mission) :
|
|
mission(_mission) {}
|
|
|
|
// mission_type returns the MAV_MISSION mavlink enumeration value
|
|
// which this module is responsible for handling
|
|
MAV_MISSION_TYPE mission_type() const override {
|
|
return MAV_MISSION_TYPE_MISSION;
|
|
}
|
|
|
|
// complete() is called by the base class after all waypoints have
|
|
// been received. _link is the link which the last item was
|
|
// transfered on.
|
|
MAV_MISSION_RESULT complete(const GCS_MAVLINK &_link) override;
|
|
// timeout() is called by the base class in the case that the GCS
|
|
// does not transfer all waypoints to the vehicle.
|
|
void timeout() override;
|
|
// truncate() is called to set the absolute number of items. It
|
|
// must be less than or equal to the current number of items (you
|
|
// can't truncate-to a longer list)
|
|
void truncate(const mavlink_mission_count_t &packet) override;
|
|
|
|
protected:
|
|
|
|
// clear_all_items() is called to clear all items on the vehicle
|
|
bool clear_all_items() override WARN_IF_UNUSED;
|
|
|
|
// next_item_ap_message_id returns an item from the ap_message
|
|
// enumeration which (when acted upon by the GCS class) will send
|
|
// a mavlink message to the GCS requesting it upload the next
|
|
// required waypoint.
|
|
ap_message next_item_ap_message_id() const override {
|
|
return MSG_NEXT_MISSION_REQUEST_WAYPOINTS;
|
|
}
|
|
|
|
private:
|
|
AP_Mission &mission;
|
|
|
|
// append_item() is called by the base class to add the supplied
|
|
// item to the end of the list of stored items.
|
|
MAV_MISSION_RESULT append_item(const mavlink_mission_item_int_t &) override WARN_IF_UNUSED;
|
|
|
|
// get_item() fills in ret_packet based on packet; _link is the
|
|
// link the request was received on, and msg is the undecoded
|
|
// request. Note that msg may not actually decode to a
|
|
// request_int_t!
|
|
MAV_MISSION_RESULT get_item(const GCS_MAVLINK &_link,
|
|
const mavlink_message_t &msg,
|
|
const mavlink_mission_request_int_t &packet,
|
|
mavlink_mission_item_int_t &ret_packet) override WARN_IF_UNUSED;
|
|
|
|
// item_count() returns the number of stored items
|
|
uint16_t item_count() const override;
|
|
|
|
// item_count() returns the maximum number of items which could be
|
|
// stored on-board
|
|
uint16_t max_items() const override;
|
|
|
|
// replace_item() replaces an item in the stored list
|
|
MAV_MISSION_RESULT replace_item(const mavlink_mission_item_int_t &) override WARN_IF_UNUSED;
|
|
|
|
};
|
|
|