From 4a4d53c7ff44f66f221a561f80d4d1ddb5163189 Mon Sep 17 00:00:00 2001 From: Michael Carroll Date: Tue, 15 Aug 2023 16:29:58 +0000 Subject: [PATCH] Use correct link indicies when constructing fixed constraints Signed-off-by: Michael Carroll --- bullet-featherstone/src/JointFeatures.cc | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/bullet-featherstone/src/JointFeatures.cc b/bullet-featherstone/src/JointFeatures.cc index 79e4113aa..dd8e72c6a 100644 --- a/bullet-featherstone/src/JointFeatures.cc +++ b/bullet-featherstone/src/JointFeatures.cc @@ -303,11 +303,11 @@ Identity JointFeatures::AttachFixedJoint( const BaseLink3dPtr &_parent, const std::string &_name) { - auto linkInfo = this->ReferenceInterface(_childID); - auto modelInfo = this->ReferenceInterface(linkInfo->model); - auto parentLinkInfo = this->ReferenceInterface( + auto *linkInfo = this->ReferenceInterface(_childID); + auto *modelInfo = this->ReferenceInterface(linkInfo->model); + auto *parentLinkInfo = this->ReferenceInterface( _parent->FullIdentity()); - auto parentModelInfo = this->ReferenceInterface( + auto *parentModelInfo = this->ReferenceInterface( parentLinkInfo->model); auto *world = this->ReferenceInterface(modelInfo->world); @@ -322,16 +322,18 @@ Identity JointFeatures::AttachFixedJoint( linkInfo->model }); - auto jointInfo = this->ReferenceInterface(jointID); + auto parentLinkIdx = parentLinkInfo->indexInModel.value_or(-1); + auto childLinkIdx = linkInfo->indexInModel.value_or(-1); + auto *jointInfo = this->ReferenceInterface(jointID); jointInfo->fixedConstraint = std::make_shared( - parentModelInfo->body.get(), -1, - modelInfo->body.get(), -1, + parentModelInfo->body.get(), parentLinkIdx, + modelInfo->body.get(), childLinkIdx, btVector3(0, 0, 0), btVector3(0, 0, 0), btMatrix3x3::getIdentity(), btMatrix3x3::getIdentity()); - if (world && world->world) + if (world != nullptr && world->world) { world->world->addMultiBodyConstraint(jointInfo->fixedConstraint.get()); return this->GenerateIdentity(jointID, this->joints.at(jointID));