Nav2 Navigation Stack - jazzy  jazzy
ROS 2 Navigation Stack
progress_checker_selector_node.cpp
1 // Copyright (c) 2024 Open Navigation LLC
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #include <string>
16 #include <memory>
17 
18 #include "std_msgs/msg/string.hpp"
19 
20 #include "nav2_behavior_tree/plugins/action/progress_checker_selector_node.hpp"
21 
22 #include "rclcpp/rclcpp.hpp"
23 
24 namespace nav2_behavior_tree
25 {
26 
27 using std::placeholders::_1;
28 
30  const std::string & name,
31  const BT::NodeConfiguration & conf)
32 : BT::SyncActionNode(name, conf)
33 {
34  node_ = config().blackboard->get<rclcpp::Node::SharedPtr>("node");
35 
36  getInput("topic_name", topic_name_);
37 
38  rclcpp::QoS qos(rclcpp::KeepLast(1));
39  qos.transient_local().reliable();
40 
41  progress_checker_selector_sub_ = node_->create_subscription<std_msgs::msg::String>(
42  topic_name_, qos, std::bind(&ProgressCheckerSelector::callbackProgressCheckerSelect, this, _1));
43 }
44 
45 BT::NodeStatus ProgressCheckerSelector::tick()
46 {
47  rclcpp::spin_some(node_);
48 
49  // This behavior always use the last selected progress checker received from the topic input.
50  // When no input is specified it uses the default goaprogressl checker.
51  // If the default progress checker is not specified then we work in
52  // "required progress checker mode": In this mode, the behavior returns failure if the progress
53  // checker selection is not received from the topic input.
54  if (last_selected_progress_checker_.empty()) {
55  std::string default_progress_checker;
56  getInput("default_progress_checker", default_progress_checker);
57  if (default_progress_checker.empty()) {
58  return BT::NodeStatus::FAILURE;
59  } else {
60  last_selected_progress_checker_ = default_progress_checker;
61  }
62  }
63 
64  setOutput("selected_progress_checker", last_selected_progress_checker_);
65 
66  return BT::NodeStatus::SUCCESS;
67 }
68 
69 void
70 ProgressCheckerSelector::callbackProgressCheckerSelect(const std_msgs::msg::String::SharedPtr msg)
71 {
72  last_selected_progress_checker_ = msg->data;
73 }
74 
75 } // namespace nav2_behavior_tree
76 
77 #include "behaviortree_cpp/bt_factory.h"
78 BT_REGISTER_NODES(factory)
79 {
80  factory.registerNodeType<nav2_behavior_tree::ProgressCheckerSelector>("ProgressCheckerSelector");
81 }
The ProgressCheckerSelector behavior is used to switch the progress checker of the controller server....
ProgressCheckerSelector(const std::string &xml_tag_name, const BT::NodeConfiguration &conf)
A constructor for nav2_behavior_tree::ProgressCheckerSelector.