diff --git a/controller_interface/include/controller_interface/chainable_controller_interface.hpp b/controller_interface/include/controller_interface/chainable_controller_interface.hpp index 79580495f3d..73d6b4d596d 100644 --- a/controller_interface/include/controller_interface/chainable_controller_interface.hpp +++ b/controller_interface/include/controller_interface/chainable_controller_interface.hpp @@ -41,7 +41,8 @@ class ChainableControllerInterface : public ControllerInterfaceBase virtual ~ChainableControllerInterface() = default; /** - * Control step update. Command interfaces are updated based on on reference inputs and current states. + * Control step update. Command interfaces are updated based on on reference inputs and current + * states. * **The method called in the (real-time) control loop.** * * \param[in] time The time at the start of this control loop iteration @@ -67,11 +68,11 @@ class ChainableControllerInterface : public ControllerInterfaceBase bool is_in_chained_mode() const final; CONTROLLER_INTERFACE_PUBLIC - virtual bool toggle_references_from_subscribers(bool enable) final; + bool toggle_references_from_subscribers(bool enable) final; protected: - /// Virtual method that each chainable controller should implement to export its read-only chainable - /// interfaces. + /// Virtual method that each chainable controller should implement to export its read-only + /// chainable interfaces. /** * Each chainable controller implements this methods where all its state(read only) interfaces are * exported. The method has the same meaning as `export_estimated_interfaces` method from @@ -81,8 +82,8 @@ class ChainableControllerInterface : public ControllerInterfaceBase */ virtual std::vector on_export_estimated_interfaces() = 0; - /// Virtual method that each chainable controller should implement to export its read/write chainable - /// interfaces. + /// Virtual method that each chainable controller should implement to export its read/write + /// chainable interfaces. /** * Each chainable controller implements this methods where all input (command) interfaces are * exported. The method has the same meaning as `export_command_interface` method from @@ -100,7 +101,9 @@ class ChainableControllerInterface : public ControllerInterfaceBase * * \param[in] flag marking a switch to or from chained mode. * - * \returns true if controller successfully switched between "chained" and "external" mode. \default returns true so the method don't have to be overridden if controller can always switch chained mode. + * \returns true if controller successfully switched between "chained" and "external" mode. + * \default returns true so the method don't have to be overridden if controller can always switch + * chained mode. */ virtual bool on_set_chained_mode(bool chained_mode); @@ -138,7 +141,8 @@ class ChainableControllerInterface : public ControllerInterfaceBase /// A flag marking if a chainable controller is currently preceded by another controller. bool in_chained_mode_ = false; - /// A flag marking whether to use references from subscribers or from the interfaces as input commands + /// A flag marking whether to use references from subscribers or from the interfaces as input + /// commands bool use_references_from_subscribers_ = false; }; diff --git a/controller_interface/include/controller_interface/controller_interface.hpp b/controller_interface/include/controller_interface/controller_interface.hpp index 85da8f2c62d..8f3e9a08f81 100644 --- a/controller_interface/include/controller_interface/controller_interface.hpp +++ b/controller_interface/include/controller_interface/controller_interface.hpp @@ -80,7 +80,7 @@ class ControllerInterface : public controller_interface::ControllerInterfaceBase * @return false */ CONTROLLER_INTERFACE_PUBLIC - virtual bool toggle_references_from_subscribers(bool enable) final; + bool toggle_references_from_subscribers(bool enable) final; }; using ControllerInterfaceSharedPtr = std::shared_ptr; diff --git a/controller_interface/include/controller_interface/controller_interface_base.hpp b/controller_interface/include/controller_interface/controller_interface_base.hpp index 75b6aaffd8d..077841d6e5f 100644 --- a/controller_interface/include/controller_interface/controller_interface_base.hpp +++ b/controller_interface/include/controller_interface/controller_interface_base.hpp @@ -228,7 +228,7 @@ class ControllerInterfaceBase : public rclcpp_lifecycle::node_interfaces::Lifecy CONTROLLER_INTERFACE_PUBLIC virtual bool is_in_chained_mode() const = 0; - /// A method to enable the useage of references from subscribers + /// A method to enable the usage of references from subscribers /** * Enable or disable the retrieval of references for a chainable controller. This methods helps * to toggle between the usage of reference from the subscribers or the external interfaces to diff --git a/controller_manager/include/controller_manager/controller_manager.hpp b/controller_manager/include/controller_manager/controller_manager.hpp index 25a74fe4dfc..3af987cfc63 100644 --- a/controller_manager/include/controller_manager/controller_manager.hpp +++ b/controller_manager/include/controller_manager/controller_manager.hpp @@ -318,8 +318,8 @@ class ControllerManager : public rclcpp::Node const std::string & command_interface); /** - * Clear request lists used when switching controllers. The lists are shared between "callback" and - * "control loop" threads. + * Clear request lists used when switching controllers. The lists are shared between "callback" + * and "control loop" threads. */ void clear_requests(); @@ -383,7 +383,7 @@ class ControllerManager : public rclcpp::Node const std::vector & controllers, int strictness, const ControllersListIterator controller_it); - ///Sets if the parsed vector of controller's reference interfacs are available to use or not + /// Sets if the parsed vector of controller's reference interfacs are available to use or not /** * Sets the availability status of the reference interfaces of the given list of controllers * @param[in] controllers list @@ -438,7 +438,8 @@ class ControllerManager : public rclcpp::Node * lists match and returns a reference to it * This referenced list can be modified safely until switch_updated_controller_list() * is called, at this point the RT thread may start using it at any time - * \param[in] guard Guard needed to make sure the caller is the only one accessing the unused by rt list + * \param[in] guard Guard needed to make sure the caller is the only one accessing the unused by + * rt list */ std::vector & get_unused_list( const std::lock_guard & guard); @@ -446,7 +447,8 @@ class ControllerManager : public rclcpp::Node /// get_updated_list Returns a const reference to the most updated list. /** * \warning May or may not being used by the realtime thread, read-only reference for safety - * \param[in] guard Guard needed to make sure the caller is the only one accessing the unused by rt list + * \param[in] guard Guard needed to make sure the caller is the only one accessing the unused by + * rt list */ const std::vector & get_updated_list( const std::lock_guard & guard) const; @@ -454,7 +456,8 @@ class ControllerManager : public rclcpp::Node /** * switch_updated_list Switches the "updated" and "outdated" lists, and waits * until the RT thread is using the new "updated" list. - * \param[in] guard Guard needed to make sure the caller is the only one accessing the unused by rt list + * \param[in] guard Guard needed to make sure the caller is the only one accessing the unused by + * rt list */ void switch_updated_list(const std::lock_guard & guard); diff --git a/controller_manager/src/controller_manager.cpp b/controller_manager/src/controller_manager.cpp index 58d695ce824..99ea40bf16f 100644 --- a/controller_manager/src/controller_manager.cpp +++ b/controller_manager/src/controller_manager.cpp @@ -70,9 +70,9 @@ bool controller_name_compare(const controller_manager::ControllerSpec & a, const /// Checks if an interface belongs to a controller based on its prefix. /** - * A State/Command interface can be provided by a controller in which case is called "estimated/reference" - * interface. - * This means that the @interface_name starts with the name of a controller. + * A State/Command interface can be provided by a controller in which case is called + * "estimated/reference" interface. This means that the @interface_name starts with the name of a + * controller. * * \param[in] interface_name to be found in the map. * \param[in] controllers list of controllers to compare their names to interface's prefix. @@ -2007,7 +2007,8 @@ void ControllerManager::propagate_deactivation_of_chained_mode( ControllersListIterator following_ctrl_it; if (is_interface_a_chained_interface(ctrl_itf_name, controllers, following_ctrl_it)) { - // If the preceding controller's estimated interfaces are in use by other controllers, then maintain the chained mode + // If the preceding controller's estimated interfaces are in use by other controllers, + // then maintain the chained mode if (is_controller_estimated_interfaces_inuse_by_other_controllers( following_ctrl_it->info.name, controllers, deactivate_request_)) { @@ -2016,7 +2017,8 @@ void ControllerManager::propagate_deactivation_of_chained_mode( to_use_references_from_subscribers_.end(), following_ctrl_it->info.name); if (found_it == to_use_references_from_subscribers_.end()) { - // In this case we check if the interface is state only and then add to use references_from_subscribers list + // In this case we check if the interface is state only and then add to use + // references_from_subscribers list to_use_references_from_subscribers_.push_back(following_ctrl_it->info.name); RCLCPP_DEBUG( get_logger(), "Adding controller '%s' in 'use references from subscriber' request.", @@ -2267,7 +2269,8 @@ controller_interface::return_type ControllerManager::check_preceeding_controller // strictness == // controller_manager_msgs::srv::SwitchController::Request::MANIPULATE_CONTROLLERS_CHAIN) // { - // // insert to the begin of activate request list to be activated before preceding controller + // // insert to the begin of activate request list to be activated before preceding + // controller // activate_request_.insert(activate_request_.begin(), preceding_ctrl_name); // } } diff --git a/controller_manager/test/test_chainable_controller/test_chainable_controller.cpp b/controller_manager/test/test_chainable_controller/test_chainable_controller.cpp index 1b24ebce601..69a37970b03 100644 --- a/controller_manager/test/test_chainable_controller/test_chainable_controller.cpp +++ b/controller_manager/test/test_chainable_controller/test_chainable_controller.cpp @@ -108,7 +108,8 @@ controller_interface::return_type TestChainableController::update_and_write_comm { estimated_interfaces_data_[i] = command_interfaces_[i].get_value() * CONTROLLER_DT; } - // If there is no command interface and if there is a state interface then just forward the same value as in the state interface + // If there is no command interface and if there is a state interface then just forward the same + // value as in the state interface for (size_t i = 0; i < estimated_interface_names_.size() && i < state_interfaces_.size() && command_interfaces_.empty(); ++i) diff --git a/controller_manager/test/test_chainable_controller/test_chainable_controller.hpp b/controller_manager/test/test_chainable_controller/test_chainable_controller.hpp index 0a9a06fb1a2..96c961a1356 100644 --- a/controller_manager/test/test_chainable_controller/test_chainable_controller.hpp +++ b/controller_manager/test/test_chainable_controller/test_chainable_controller.hpp @@ -89,7 +89,7 @@ class TestChainableController : public controller_interface::ChainableController void set_estimated_interface_names(const std::vector & estimated_interface_names); CONTROLLER_MANAGER_PUBLIC - void set_imu_sensor_name(const std::string &name); + void set_imu_sensor_name(const std::string & name); size_t internal_counter; controller_interface::InterfaceConfiguration cmd_iface_cfg_; diff --git a/controller_manager/test/test_controllers_chaining_with_controller_manager.cpp b/controller_manager/test/test_controllers_chaining_with_controller_manager.cpp index 348fcd240a1..8d16e40cd38 100644 --- a/controller_manager/test/test_controllers_chaining_with_controller_manager.cpp +++ b/controller_manager/test/test_controllers_chaining_with_controller_manager.cpp @@ -928,7 +928,8 @@ TEST_P( ASSERT_TRUE(diff_drive_controller->is_in_chained_mode()); EXPECT_EQ( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, diff_drive_controller->get_state().id()); - // SensorFusionController continues to stay in the chained mode as it is still using the estimated interfaces + // SensorFusionController continues to stay in the chained mode as it is still using the estimated + // interfaces ASSERT_TRUE(sensor_fusion_controller->is_in_chained_mode()); EXPECT_EQ( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, sensor_fusion_controller->get_state().id()); @@ -938,7 +939,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, robot_localization_controller->get_state().id()); - // Deactivate the robot localization controller and see that the sensor fusion controller is still active but not in the chained mode + // Deactivate the robot localization controller and see that the sensor fusion controller is still + // active but not in the chained mode DeactivateAndCheckController( robot_localization_controller, ROBOT_LOCALIZATION_CONTROLLER, {}, 8u); EXPECT_TRUE(pid_left_wheel_controller->is_in_chained_mode()); @@ -972,7 +974,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_INACTIVE, robot_localization_controller->get_state().id()); - // Deactivate the sensor_fusion controller and see that the diff_drive_controller is still active but not in the chained mode + // Deactivate the sensor_fusion controller and see that the diff_drive_controller is still active + // but not in the chained mode DeactivateAndCheckController(sensor_fusion_controller, SENSOR_FUSION_CONTROLLER, {}, 14u); EXPECT_TRUE(pid_left_wheel_controller->is_in_chained_mode()); EXPECT_TRUE(pid_right_wheel_controller->is_in_chained_mode()); @@ -989,7 +992,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_INACTIVE, robot_localization_controller->get_state().id()); - // Deactivate the diff_drive_controller as all it's following controllers that uses it's interfaces are deactivated + // Deactivate the diff_drive_controller as all it's following controllers that uses it's + // interfaces are deactivated DeactivateAndCheckController( diff_drive_controller, DIFF_DRIVE_CONTROLLER, DIFF_DRIVE_CLAIMED_INTERFACES, 20u); EXPECT_FALSE(pid_left_wheel_controller->is_in_chained_mode()); @@ -1190,7 +1194,8 @@ TEST_P( ActivateAndCheckController(robot_localization_controller, ROBOT_LOCALIZATION_CONTROLLER, {}, 1u); ActivateAndCheckController(odom_publisher_controller, ODOM_PUBLISHER_CONTROLLER, {}, 1u); - // Verify that the other preceding controller is deactivated (diff_drive_controller_two) and other depending controllers are active + // Verify that the other preceding controller is deactivated (diff_drive_controller_two) and other + // depending controllers are active EXPECT_EQ( lifecycle_msgs::msg::State::PRIMARY_STATE_INACTIVE, diff_drive_controller_two->get_state().id()); @@ -1494,10 +1499,10 @@ TEST_P( {controller_interface::return_type::OK, std::future_status::ready, lifecycle_msgs::msg::State::PRIMARY_STATE_INACTIVE}}}; - // Test switch 'from chained mode' when controllers are deactivated and possible combination of disabling - // controllers that use reference/estimated interfaces of the other controller. - // This is important to check that deactivation is not trigger irrespective of the type (reference/estimated) - // interface that is shared among the other controllers + // Test switch 'from chained mode' when controllers are deactivated and possible combination of + // disabling controllers that use reference/estimated interfaces of the other controller. This is + // important to check that deactivation is not trigger irrespective of the type + // (reference/estimated) interface that is shared among the other controllers // PositionController is deactivated --> DiffDrive controller still continues in chained mode // As the DiffDriveController is in chained mode, right now we tend to also deactivate @@ -1511,7 +1516,8 @@ TEST_P( ASSERT_TRUE(sensor_fusion_controller->is_in_chained_mode()); EXPECT_EQ( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, diff_drive_controller->get_state().id()); - // SensorFusionController continues to stay in the chained mode as it is still using the estimated interfaces + // SensorFusionController continues to stay in the chained mode as it is still using the estimated + // interfaces EXPECT_EQ( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, sensor_fusion_controller->get_state().id()); EXPECT_EQ( @@ -1521,7 +1527,8 @@ TEST_P( robot_localization_controller->get_state().id()); // DiffDrive (preceding) controller is activated --> PID controller in chained mod - // Let's try to deactivate the diff_drive_control, it should fail as there are still other controllers that use it's resources + // Let's try to deactivate the diff_drive_control, it should fail as there are still other + // controllers that use it's resources DeactivateController( DIFF_DRIVE_CONTROLLER, expected.at(test_param.strictness).return_type, expected.at(test_param.strictness).future_status); @@ -1542,8 +1549,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, robot_localization_controller->get_state().id()); - // Trying to deactivate the sensor fusion controller, however, it won't be deactivated as the robot - // localization controller is still active + // Trying to deactivate the sensor fusion controller, however, it won't be deactivated as the + // robot localization controller is still active DeactivateAndCheckController( sensor_fusion_controller, SENSOR_FUSION_CONTROLLER, {}, 0u, true, expected.at(test_param.strictness).return_type, @@ -1562,7 +1569,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_ACTIVE, robot_localization_controller->get_state().id()); - // Deactivate the robot localization controller and see that the sensor fusion controller is still active but not in the chained mode + // Deactivate the robot localization controller and see that the sensor fusion controller is still + // active but not in the chained mode DeactivateAndCheckController( robot_localization_controller, ROBOT_LOCALIZATION_CONTROLLER, {}, 0u); EXPECT_TRUE(pid_left_wheel_controller->is_in_chained_mode()); @@ -1596,7 +1604,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_INACTIVE, robot_localization_controller->get_state().id()); - // Deactivate the odometry publisher controller and now the diff_drive should continue active but not in chained mode + // Deactivate the odometry publisher controller and now the diff_drive should continue active but + // not in chained mode DeactivateAndCheckController(odom_publisher_controller, ODOM_PUBLISHER_CONTROLLER, {}, 0u); EXPECT_TRUE(pid_left_wheel_controller->is_in_chained_mode()); EXPECT_TRUE(pid_right_wheel_controller->is_in_chained_mode()); @@ -1613,7 +1622,8 @@ TEST_P( lifecycle_msgs::msg::State::PRIMARY_STATE_INACTIVE, robot_localization_controller->get_state().id()); - // Deactivate the diff_drive_controller as all it's following controllers that uses it's interfaces are deactivated + // Deactivate the diff_drive_controller as all it's following controllers that uses it's + // interfaces are deactivated DeactivateAndCheckController( diff_drive_controller, DIFF_DRIVE_CONTROLLER, DIFF_DRIVE_CLAIMED_INTERFACES, 0u); EXPECT_FALSE(pid_left_wheel_controller->is_in_chained_mode()); diff --git a/joint_limits_interface/test/joint_limits_urdf_test.cpp b/joint_limits_interface/test/joint_limits_urdf_test.cpp index 55effc7117a..f38106a4083 100644 --- a/joint_limits_interface/test/joint_limits_urdf_test.cpp +++ b/joint_limits_interface/test/joint_limits_urdf_test.cpp @@ -14,10 +14,10 @@ /// \author Adolfo Rodriguez Tsouroukdissian -#include - #include +#include + #include class JointLimitsUrdfTest : public ::testing::Test