/* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #pragma once #include #if AP_GRIPPER_ENABLED class AP_Gripper_Backend { public: AP_Gripper_Backend(struct AP_Gripper::Backend_Config &_config) : config(_config) { } // initialise the gripper backend void init(); // update - should be called at at least 10hz void update(); // grab - move the servo to the grab position virtual void grab() = 0; // release - move the servo output to the release position virtual void release() = 0; // valid - returns true if the backend should be working virtual bool valid() const { return true; }; // released - returns true if currently in released position virtual bool released() const = 0; // grabbed - returns true if currently in grabbed position virtual bool grabbed() const = 0; // type-specific initialisations: virtual void init_gripper() = 0; // type-specific periodic updates: virtual void update_gripper() { }; protected: uint32_t _last_grab_or_release; // ms; time last grab or release happened struct AP_Gripper::Backend_Config &config; }; #endif // AP_GRIPPER_ENABLED