rclcpp  master
C++ ROS Client Library API
memory_strategy.hpp
Go to the documentation of this file.
1 // Copyright 2015 Open Source Robotics Foundation, Inc.
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 #ifndef RCLCPP__MEMORY_STRATEGY_HPP_
16 #define RCLCPP__MEMORY_STRATEGY_HPP_
17 
18 #include <memory>
19 #include <vector>
20 
21 #include "rcl/allocator.h"
22 #include "rcl/wait.h"
23 
25 #include "rclcpp/macros.hpp"
28 
29 namespace rclcpp
30 {
31 namespace memory_strategy
32 {
33 
35 
41 {
42 public:
44  using WeakNodeVector = std::vector<rclcpp::node_interfaces::NodeBaseInterface::WeakPtr>;
45 
46  virtual bool collect_entities(const WeakNodeVector & weak_nodes) = 0;
47 
48  virtual size_t number_of_ready_subscriptions() const = 0;
49  virtual size_t number_of_ready_services() const = 0;
50  virtual size_t number_of_ready_clients() const = 0;
51  virtual size_t number_of_ready_timers() const = 0;
52  virtual size_t number_of_guard_conditions() const = 0;
53 
54  virtual bool add_handles_to_wait_set(rcl_wait_set_t * wait_set) = 0;
55  virtual void clear_handles() = 0;
56  virtual void remove_null_handles(rcl_wait_set_t * wait_set) = 0;
57 
58  virtual void add_guard_condition(const rcl_guard_condition_t * guard_condition) = 0;
59 
60  virtual void remove_guard_condition(const rcl_guard_condition_t * guard_condition) = 0;
61 
62  virtual void
63  get_next_subscription(
64  rclcpp::executor::AnyExecutable & any_exec,
65  const WeakNodeVector & weak_nodes) = 0;
66 
67  virtual void
68  get_next_service(
69  rclcpp::executor::AnyExecutable & any_exec,
70  const WeakNodeVector & weak_nodes) = 0;
71 
72  virtual void
73  get_next_client(
74  rclcpp::executor::AnyExecutable & any_exec,
75  const WeakNodeVector & weak_nodes) = 0;
76 
77  virtual rcl_allocator_t
78  get_allocator() = 0;
79 
80  static rclcpp::SubscriptionBase::SharedPtr
81  get_subscription_by_handle(
82  std::shared_ptr<const rcl_subscription_t> subscriber_handle,
83  const WeakNodeVector & weak_nodes);
84 
85  static rclcpp::ServiceBase::SharedPtr
86  get_service_by_handle(
87  std::shared_ptr<const rcl_service_t> service_handle,
88  const WeakNodeVector & weak_nodes);
89 
90  static rclcpp::ClientBase::SharedPtr
91  get_client_by_handle(
92  std::shared_ptr<const rcl_client_t> client_handle,
93  const WeakNodeVector & weak_nodes);
94 
95  static rclcpp::node_interfaces::NodeBaseInterface::SharedPtr
96  get_node_by_group(
97  rclcpp::callback_group::CallbackGroup::SharedPtr group,
98  const WeakNodeVector & weak_nodes);
99 
100  static rclcpp::callback_group::CallbackGroup::SharedPtr
101  get_group_by_subscription(
102  rclcpp::SubscriptionBase::SharedPtr subscription,
103  const WeakNodeVector & weak_nodes);
104 
105  static rclcpp::callback_group::CallbackGroup::SharedPtr
106  get_group_by_service(
107  rclcpp::ServiceBase::SharedPtr service,
108  const WeakNodeVector & weak_nodes);
109 
110  static rclcpp::callback_group::CallbackGroup::SharedPtr
111  get_group_by_client(
112  rclcpp::ClientBase::SharedPtr client,
113  const WeakNodeVector & weak_nodes);
114 };
115 
116 } // namespace memory_strategy
117 } // namespace rclcpp
118 
119 #endif // RCLCPP__MEMORY_STRATEGY_HPP_
Delegate for handling memory allocations while the Executor is executing.
Definition: memory_strategy.hpp:40
Definition: allocator_common.hpp:24
Definition: subscription.hpp:51
#define RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE(...)
Definition: macros.hpp:51
#define RCLCPP_PUBLIC
Definition: visibility_control.hpp:50
Definition: client.hpp:52
Definition: service.hpp:40