19 #include "nav2_route/plugins/route_operations/rerouting_service.hpp"
25 const nav2::LifecycleNode::SharedPtr node,
26 std::shared_ptr<nav2_costmap_2d::CostmapSubscriber>,
27 const std::string & name)
29 RCLCPP_INFO(node->get_logger(),
"Configuring Rerouting service operation.");
31 logger_ = node->get_logger();
32 reroute_.store(
false);
33 service_ = node->create_service<std_srvs::srv::Trigger>(
34 std::string(node->get_name()) +
"/" +
getName() +
"/reroute",
36 std::placeholders::_1, std::placeholders::_2, std::placeholders::_3));
40 const std::shared_ptr<rmw_request_id_t>,
41 const std::shared_ptr<std_srvs::srv::Trigger::Request>,
42 std::shared_ptr<std_srvs::srv::Trigger::Response> response)
44 RCLCPP_INFO(logger_,
"A reroute has been requested!");
46 response->success =
true;
54 const geometry_msgs::msg::PoseStamped & ,
58 if (reroute_.load()) {
59 reroute_.store(
false);
60 result.reroute =
true;
69 #include "pluginlib/class_list_macros.hpp"
A route operation to process requests from an external server for rerouting.
void serviceCb(const std::shared_ptr< rmw_request_id_t > request_header, const std::shared_ptr< std_srvs::srv::Trigger::Request > request, std::shared_ptr< std_srvs::srv::Trigger::Response > response)
Service callback to trigger a reroute externally.
void configure(const nav2::LifecycleNode::SharedPtr node, std::shared_ptr< nav2_costmap_2d::CostmapSubscriber > costmap_subscriber, const std::string &name) override
Configure.
OperationResult perform(NodePtr node, EdgePtr edge_entered, EdgePtr edge_exited, const Route &route, const geometry_msgs::msg::PoseStamped &curr_pose, const Metadata *mdata=nullptr) override
The main speed limit operation to adjust the maximum speed of the vehicle.
std::string getName() override
Get name of the plugin for parameter scope mapping.
A plugin interface to perform an operation while tracking the route such as triggered from the graph ...
An object representing edges between nodes.
An object to store the nodes in the graph file.
a struct to hold return from an operation
An ordered set of nodes and edges corresponding to the planned route.