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 #include "rclcpp/waitable.hpp"
29 
30 namespace rclcpp
31 {
32 namespace memory_strategy
33 {
34 
36 
42 {
43 public:
45  using WeakNodeVector = std::vector<rclcpp::node_interfaces::NodeBaseInterface::WeakPtr>;
46 
47  virtual ~MemoryStrategy() = default;
48 
49  virtual bool collect_entities(const WeakNodeVector & weak_nodes) = 0;
50 
51  virtual size_t number_of_ready_subscriptions() const = 0;
52  virtual size_t number_of_ready_services() const = 0;
53  virtual size_t number_of_ready_clients() const = 0;
54  virtual size_t number_of_ready_timers() const = 0;
55  virtual size_t number_of_guard_conditions() const = 0;
56  virtual size_t number_of_waitables() const = 0;
57 
58  virtual bool add_handles_to_wait_set(rcl_wait_set_t * wait_set) = 0;
59  virtual void clear_handles() = 0;
60  virtual void remove_null_handles(rcl_wait_set_t * wait_set) = 0;
61 
62  virtual void add_guard_condition(const rcl_guard_condition_t * guard_condition) = 0;
63 
64  virtual void remove_guard_condition(const rcl_guard_condition_t * guard_condition) = 0;
65 
66  virtual void
67  get_next_subscription(
68  rclcpp::executor::AnyExecutable & any_exec,
69  const WeakNodeVector & weak_nodes) = 0;
70 
71  virtual void
72  get_next_service(
73  rclcpp::executor::AnyExecutable & any_exec,
74  const WeakNodeVector & weak_nodes) = 0;
75 
76  virtual void
77  get_next_client(
78  rclcpp::executor::AnyExecutable & any_exec,
79  const WeakNodeVector & weak_nodes) = 0;
80 
81  virtual void
82  get_next_waitable(
83  rclcpp::executor::AnyExecutable & any_exec,
84  const WeakNodeVector & weak_nodes) = 0;
85 
86  virtual rcl_allocator_t
87  get_allocator() = 0;
88 
89  static rclcpp::SubscriptionBase::SharedPtr
90  get_subscription_by_handle(
91  std::shared_ptr<const rcl_subscription_t> subscriber_handle,
92  const WeakNodeVector & weak_nodes);
93 
94  static rclcpp::ServiceBase::SharedPtr
95  get_service_by_handle(
96  std::shared_ptr<const rcl_service_t> service_handle,
97  const WeakNodeVector & weak_nodes);
98 
99  static rclcpp::ClientBase::SharedPtr
100  get_client_by_handle(
101  std::shared_ptr<const rcl_client_t> client_handle,
102  const WeakNodeVector & weak_nodes);
103 
104  static rclcpp::node_interfaces::NodeBaseInterface::SharedPtr
105  get_node_by_group(
106  rclcpp::callback_group::CallbackGroup::SharedPtr group,
107  const WeakNodeVector & weak_nodes);
108 
109  static rclcpp::callback_group::CallbackGroup::SharedPtr
110  get_group_by_subscription(
111  rclcpp::SubscriptionBase::SharedPtr subscription,
112  const WeakNodeVector & weak_nodes);
113 
114  static rclcpp::callback_group::CallbackGroup::SharedPtr
115  get_group_by_service(
116  rclcpp::ServiceBase::SharedPtr service,
117  const WeakNodeVector & weak_nodes);
118 
119  static rclcpp::callback_group::CallbackGroup::SharedPtr
120  get_group_by_client(
121  rclcpp::ClientBase::SharedPtr client,
122  const WeakNodeVector & weak_nodes);
123 
124  static rclcpp::callback_group::CallbackGroup::SharedPtr
125  get_group_by_waitable(
126  rclcpp::Waitable::SharedPtr waitable,
127  const WeakNodeVector & weak_nodes);
128 };
129 
130 } // namespace memory_strategy
131 } // namespace rclcpp
132 
133 #endif // RCLCPP__MEMORY_STRATEGY_HPP_
Definition: client.hpp:52
Delegate for handling memory allocations while the Executor is executing.
Definition: memory_strategy.hpp:41
Definition: allocator_common.hpp:24
#define RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE(...)
Definition: macros.hpp:51
#define RCLCPP_PUBLIC
Definition: visibility_control.hpp:50
Definition: subscription.hpp:51
Definition: waitable.hpp:26
Definition: service.hpp:40