From 620152bb00d5ecd1bc75cfaaa2ca1e27a5e5e0fc Mon Sep 17 00:00:00 2001 From: Tyler Marr Date: Wed, 4 Oct 2023 16:34:56 -0500 Subject: [PATCH] Make `free_joint_state` parsing more generalized --- .../ikfast/ikfast_factory_boilerplate.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/tesseract_kinematics/ikfast/include/tesseract_kinematics/ikfast/ikfast_factory_boilerplate.h b/tesseract_kinematics/ikfast/include/tesseract_kinematics/ikfast/ikfast_factory_boilerplate.h index 5f25db1dff0..ca99c0f42be 100644 --- a/tesseract_kinematics/ikfast/include/tesseract_kinematics/ikfast/ikfast_factory_boilerplate.h +++ b/tesseract_kinematics/ikfast/include/tesseract_kinematics/ikfast/ikfast_factory_boilerplate.h @@ -70,10 +70,10 @@ class IKFastInvKinFactory : public InvKinFactory // Get the free joint states if (YAML::Node free_joint_states_node = config["free_joint_states"]) { - for (auto it = free_joint_states_node.begin(); it != free_joint_states_node.end(); ++it) + for (std::size_t idx = 0; idx < free_joint_states_node.size(); ++idx) { // Check the joints specification - if (it->second.size() != free_joints_required) + if (free_joint_states_node[idx].size() != free_joints_required) { std::stringstream ss; ss << "IKFastInvKinFactory, Number of active joints (" << active_joints.size() @@ -81,7 +81,7 @@ class IKFastInvKinFactory : public InvKinFactory << ") and the number of free joints (" << free_joint_states_map.size() << ")"; throw std::runtime_error(ss.str()); } - free_joint_states_map[it->first.as()] = it->second.as>(); + free_joint_states_map[idx] = free_joint_states_node[idx].as>(); } } else