#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. void 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; };