.. _program_listing_file_include_rclcpp_node_interfaces_node_parameters_interface.hpp: Program Listing for File node_parameters_interface.hpp ====================================================== |exhale_lsh| :ref:`Return to documentation for file ` (``include/rclcpp/node_interfaces/node_parameters_interface.hpp``) .. |exhale_lsh| unicode:: U+021B0 .. UPWARDS ARROW WITH TIP LEFTWARDS .. code-block:: cpp // Copyright 2016 Open Source Robotics Foundation, Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef RCLCPP__NODE_INTERFACES__NODE_PARAMETERS_INTERFACE_HPP_ #define RCLCPP__NODE_INTERFACES__NODE_PARAMETERS_INTERFACE_HPP_ #include #include #include #include #include "rcl_interfaces/msg/list_parameters_result.hpp" #include "rcl_interfaces/msg/parameter_descriptor.hpp" #include "rcl_interfaces/msg/set_parameters_result.hpp" #include "rclcpp/macros.hpp" #include "rclcpp/parameter.hpp" #include "rclcpp/visibility_control.hpp" namespace rclcpp { namespace node_interfaces { struct OnSetParametersCallbackHandle { RCLCPP_SMART_PTR_DEFINITIONS(OnSetParametersCallbackHandle) using OnParametersSetCallbackType = std::function< rcl_interfaces::msg::SetParametersResult( const std::vector &)>; OnParametersSetCallbackType callback; }; class NodeParametersInterface { public: RCLCPP_SMART_PTR_ALIASES_ONLY(NodeParametersInterface) RCLCPP_PUBLIC virtual ~NodeParametersInterface() = default; RCLCPP_PUBLIC virtual const rclcpp::ParameterValue & declare_parameter( const std::string & name, const rclcpp::ParameterValue & default_value, const rcl_interfaces::msg::ParameterDescriptor & parameter_descriptor = rcl_interfaces::msg::ParameterDescriptor(), bool ignore_override = false) = 0; RCLCPP_PUBLIC virtual const rclcpp::ParameterValue & declare_parameter( const std::string & name, rclcpp::ParameterType type, const rcl_interfaces::msg::ParameterDescriptor & parameter_descriptor = rcl_interfaces::msg::ParameterDescriptor(), bool ignore_override = false) = 0; RCLCPP_PUBLIC virtual void undeclare_parameter(const std::string & name) = 0; RCLCPP_PUBLIC virtual bool has_parameter(const std::string & name) const = 0; RCLCPP_PUBLIC virtual std::vector set_parameters(const std::vector & parameters) = 0; RCLCPP_PUBLIC virtual rcl_interfaces::msg::SetParametersResult set_parameters_atomically( const std::vector & parameters) = 0; /* * \param[in] names a list of parameter names to check. * \return the list of parameters that were found. * Any parameter not found is omitted from the returned list. */ RCLCPP_PUBLIC virtual std::vector get_parameters(const std::vector & names) const = 0; /* * \param[in] name the name of the parameter to look for. * \return the parameter if it exists on the node. * \throws std::out_of_range if the parameter does not exist on the node. */ RCLCPP_PUBLIC virtual rclcpp::Parameter get_parameter(const std::string & name) const = 0; /* * \param[in] name the name of the parameter to look for. * \param[out] parameter the description if parameter exists on the node. * \return true if the parameter exists on the node, or * \return false if the parameter does not exist. */ RCLCPP_PUBLIC virtual bool get_parameter( const std::string & name, rclcpp::Parameter & parameter) const = 0; /* * \param[in] prefix the name of the prefix to look for. * \param[out] parameters a map of parameters that matched the prefix. * \return true if any parameters with the prefix exists on the node, or * \return false otherwise. */ RCLCPP_PUBLIC virtual bool get_parameters_by_prefix( const std::string & prefix, std::map & parameters) const = 0; RCLCPP_PUBLIC virtual std::vector describe_parameters(const std::vector & names) const = 0; RCLCPP_PUBLIC virtual std::vector get_parameter_types(const std::vector & names) const = 0; RCLCPP_PUBLIC virtual rcl_interfaces::msg::ListParametersResult list_parameters(const std::vector & prefixes, uint64_t depth) const = 0; using OnParametersSetCallbackType = OnSetParametersCallbackHandle::OnParametersSetCallbackType; RCLCPP_PUBLIC virtual OnSetParametersCallbackHandle::SharedPtr add_on_set_parameters_callback(OnParametersSetCallbackType callback) = 0; RCLCPP_PUBLIC virtual void remove_on_set_parameters_callback(const OnSetParametersCallbackHandle * const handler) = 0; RCLCPP_PUBLIC virtual const std::map & get_parameter_overrides() const = 0; }; } // namespace node_interfaces } // namespace rclcpp #endif // RCLCPP__NODE_INTERFACES__NODE_PARAMETERS_INTERFACE_HPP_