15 #ifndef RCLCPP__PARAMETER_CLIENT_HPP_ 16 #define RCLCPP__PARAMETER_CLIENT_HPP_ 23 #include "rcl_interfaces/msg/parameter.hpp" 24 #include "rcl_interfaces/msg/parameter_event.hpp" 25 #include "rcl_interfaces/msg/parameter_value.hpp" 26 #include "rcl_interfaces/srv/describe_parameters.hpp" 27 #include "rcl_interfaces/srv/get_parameter_types.hpp" 28 #include "rcl_interfaces/srv/get_parameters.hpp" 29 #include "rcl_interfaces/srv/list_parameters.hpp" 30 #include "rcl_interfaces/srv/set_parameters.hpp" 31 #include "rcl_interfaces/srv/set_parameters_atomically.hpp" 43 namespace parameter_client
53 const rclcpp::node_interfaces::NodeBaseInterface::SharedPtr node_base_interface,
54 const rclcpp::node_interfaces::NodeTopicsInterface::SharedPtr node_topics_interface,
55 const rclcpp::node_interfaces::NodeGraphInterface::SharedPtr node_graph_interface,
56 const rclcpp::node_interfaces::NodeServicesInterface::SharedPtr node_services_interface,
62 const rclcpp::node::Node::SharedPtr node,
72 > callback =
nullptr);
80 > callback =
nullptr);
88 > callback =
nullptr);
96 > callback =
nullptr);
105 > callback =
nullptr);
110 typename SubscriptionT =
117 MessageMemoryStrategy<rcl_interfaces::msg::ParameterEvent, Alloc>::create_default();
120 rcl_interfaces::msg::ParameterEvent, CallbackT, Alloc, SubscriptionT>(
121 this->node_topics_interface_.get(),
123 std::forward<CallbackT>(callback),
124 rmw_qos_profile_default,
129 std::make_shared<Alloc>());
136 template<
typename RatioT = std::milli>
142 std::chrono::duration_cast<std::chrono::nanoseconds>(timeout)
152 const rclcpp::node_interfaces::NodeTopicsInterface::SharedPtr node_topics_interface_;
155 get_parameter_types_client_;
158 set_parameters_atomically_client_;
161 describe_parameters_client_;
172 rclcpp::node::Node::SharedPtr node,
176 SyncParametersClient(
177 rclcpp::executor::Executor::SharedPtr executor,
178 rclcpp::node::Node::SharedPtr node,
198 return parameter_not_found_handler();
200 return static_cast<T
>(vars[0].get_value<T>());
209 return get_parameter_impl(parameter_name,
210 std::function<T()>([&default_value]() -> T {
return default_value; }));
219 return get_parameter_impl(parameter_name,
233 rcl_interfaces::msg::SetParametersResult
237 rcl_interfaces::msg::ListParametersResult
242 template<
typename CallbackT>
246 return async_parameters_client_->on_parameter_event(std::forward<CallbackT>(callback));
253 return async_parameters_client_->service_is_ready();
256 template<
typename RatioT = std::milli>
261 return async_parameters_client_->wait_for_service(timeout);
265 rclcpp::executor::Executor::SharedPtr executor_;
266 rclcpp::node::Node::SharedPtr node_;
267 AsyncParametersClient::SharedPtr async_parameters_client_;
273 #endif // RCLCPP__PARAMETER_CLIENT_HPP_ Definition: parameter_client.hpp:46
std::shared_future< std::vector< rclcpp::parameter::ParameterType > > get_parameter_types(const std::vector< std::string > &names, std::function< void(std::shared_future< std::vector< rclcpp::parameter::ParameterType >>) > callback=nullptr)
Default allocation strategy for messages received by subscriptions.
Definition: message_memory_strategy.hpp:33
std::shared_future< rcl_interfaces::msg::ListParametersResult > list_parameters(const std::vector< std::string > &prefixes, uint64_t depth, std::function< void(std::shared_future< rcl_interfaces::msg::ListParametersResult >) > callback=nullptr)
Subscription implementation, templated on the type of message this subscription receives.
Definition: subscription.hpp:128
T get_parameter_impl(const std::string ¶meter_name, std::function< T()> parameter_not_found_handler)
Definition: parameter_client.hpp:191
Definition: allocator_common.hpp:24
T get_parameter(const std::string ¶meter_name)
Definition: parameter_client.hpp:216
bool wait_for_service(std::chrono::duration< int64_t, RatioT > timeout=std::chrono::duration< int64_t, RatioT >(-1))
Definition: parameter_client.hpp:258
#define RCLCPP_SMART_PTR_DEFINITIONS(...)
Definition: macros.hpp:36
bool service_is_ready() const
Definition: parameter_client.hpp:251
rclcpp::subscription::Subscription< rcl_interfaces::msg::ParameterEvent >::SharedPtr on_parameter_event(CallbackT &&callback)
Definition: parameter_client.hpp:113
AsyncParametersClient(const rclcpp::node_interfaces::NodeBaseInterface::SharedPtr node_base_interface, const rclcpp::node_interfaces::NodeTopicsInterface::SharedPtr node_topics_interface, const rclcpp::node_interfaces::NodeGraphInterface::SharedPtr node_graph_interface, const rclcpp::node_interfaces::NodeServicesInterface::SharedPtr node_services_interface, const std::string &remote_node_name="", const rmw_qos_profile_t &qos_profile=rmw_qos_profile_parameters)
std::shared_future< rcl_interfaces::msg::SetParametersResult > set_parameters_atomically(const std::vector< rclcpp::parameter::ParameterVariant > ¶meters, std::function< void(std::shared_future< rcl_interfaces::msg::SetParametersResult >) > callback=nullptr)
rclcpp::subscription::Subscription< rcl_interfaces::msg::ParameterEvent >::SharedPtr on_parameter_event(CallbackT &&callback)
Definition: parameter_client.hpp:244
rclcpp::subscription::Subscription< MessageT, AllocatorT >::SharedPtr create_subscription(rclcpp::node_interfaces::NodeTopicsInterface *node_topics, const std::string &topic_name, CallbackT &&callback, const rmw_qos_profile_t &qos_profile, rclcpp::callback_group::CallbackGroup::SharedPtr group, bool ignore_local_publications, bool use_intra_process_comms, typename rclcpp::message_memory_strategy::MessageMemoryStrategy< MessageT, AllocatorT >::SharedPtr msg_mem_strat, typename std::shared_ptr< AllocatorT > allocator)
Definition: create_subscription.hpp:31
Definition: parameter_client.hpp:165
#define RCLCPP_PUBLIC
Definition: visibility_control.hpp:50
std::shared_future< std::vector< rcl_interfaces::msg::SetParametersResult > > set_parameters(const std::vector< rclcpp::parameter::ParameterVariant > ¶meters, std::function< void(std::shared_future< std::vector< rcl_interfaces::msg::SetParametersResult >>) > callback=nullptr)
std::shared_future< std::vector< rclcpp::parameter::ParameterVariant > > get_parameters(const std::vector< std::string > &names, std::function< void(std::shared_future< std::vector< rclcpp::parameter::ParameterVariant >>) > callback=nullptr)
Definition: client.hpp:121
bool wait_for_service_nanoseconds(std::chrono::nanoseconds timeout)
Definition: parameter.hpp:36
bool service_is_ready() const
T get_parameter(const std::string ¶meter_name, const T &default_value)
Definition: parameter_client.hpp:206
bool wait_for_service(std::chrono::duration< int64_t, RatioT > timeout=std::chrono::duration< int64_t, RatioT >(-1))
Definition: parameter_client.hpp:138