diff --git a/locomotor/include/locomotor/locomotor_action_server.h b/locomotor/include/locomotor/locomotor_action_server.h index 09e4dd9..518bcee 100644 --- a/locomotor/include/locomotor/locomotor_action_server.h +++ b/locomotor/include/locomotor/locomotor_action_server.h @@ -43,6 +43,7 @@ namespace locomotor { using NewGoalCallback = std::function; +using PreemptionCallback = std::function; class LocomotorActionServer { @@ -51,12 +52,16 @@ class LocomotorActionServer void publishFeedback(const locomotor_msgs::NavigationState& nav_state); void completeNavigation(); void failNavigation(const locomotor_msgs::ResultCode& result_code); + + // Note: This is a separate method so as not to change the previous constructor parameter list + void setPremptionCallback(PreemptionCallback cb) { preemption_cb_ = cb; } protected: void preGoalCallback(); void preemptCallback(); actionlib::SimpleActionServer navigate_action_server_; locomotor_msgs::NavigateToPoseFeedback feedback_; NewGoalCallback goal_cb_; + PreemptionCallback preemption_cb_; }; } // namespace locomotor diff --git a/locomotor/src/locomotor_action_server.cpp b/locomotor/src/locomotor_action_server.cpp index ded6579..055da81 100644 --- a/locomotor/src/locomotor_action_server.cpp +++ b/locomotor/src/locomotor_action_server.cpp @@ -99,6 +99,7 @@ void LocomotorActionServer::preGoalCallback() void LocomotorActionServer::preemptCallback() { if (!navigate_action_server_.isActive()) return; + if (preemption_cb_) preemption_cb_(); locomotor_msgs::NavigateToPoseResult result; result.result_code.result_code = -1; result.result_code.message = "Preempted.";