From 07fac3a9990825c4384d3de9eface22799c828ee Mon Sep 17 00:00:00 2001 From: Silvio Traversaro Date: Fri, 5 Jul 2024 15:15:05 +0200 Subject: [PATCH] Fix bug that caused iDynTree::ModelParserOptions to be ignored (#1191) --- CMakeLists.txt | 2 +- .../codecs/include/private/URDFDocument.h | 2 +- src/model_io/codecs/src/ModelLoader.cpp | 17 +++--- src/model_io/codecs/src/URDFDocument.cpp | 4 +- .../codecs/tests/URDFModelImportUnitTest.cpp | 54 +++++++++++++++++++ 5 files changed, 69 insertions(+), 10 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 1f8baf1fab..9cfcdfe6b8 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -3,7 +3,7 @@ cmake_minimum_required(VERSION 3.16) -project(iDynTree VERSION 12.3.2 +project(iDynTree VERSION 12.3.3 LANGUAGES C CXX) # Disable in source build, unless Eclipse is used diff --git a/src/model_io/codecs/include/private/URDFDocument.h b/src/model_io/codecs/include/private/URDFDocument.h index 5d3bb246e4..9ec9a19171 100644 --- a/src/model_io/codecs/include/private/URDFDocument.h +++ b/src/model_io/codecs/include/private/URDFDocument.h @@ -43,7 +43,7 @@ class iDynTree::URDFDocument: public iDynTree::XMLDocument { } m_buffers; public: - explicit URDFDocument(XMLParserState& parserState); + explicit URDFDocument(XMLParserState& parserState, const iDynTree::ModelParserOptions& parserOptions); virtual ~URDFDocument(); iDynTree::ModelParserOptions& options(); diff --git a/src/model_io/codecs/src/ModelLoader.cpp b/src/model_io/codecs/src/ModelLoader.cpp index ba9f20c619..2036ed005a 100644 --- a/src/model_io/codecs/src/ModelLoader.cpp +++ b/src/model_io/codecs/src/ModelLoader.cpp @@ -81,9 +81,11 @@ namespace iDynTree { // Allocate parser std::shared_ptr parser = std::make_shared(); - parser->setDocumentFactory([](XMLParserState& state){ - return std::shared_ptr(new URDFDocument(state)); - }); + auto parserOptions = this->m_pimpl->m_options; + auto documentFactoryWithOptions = [parserOptions](XMLParserState& state){ + return std::shared_ptr(new URDFDocument(state, parserOptions)); + }; + parser->setDocumentFactory(documentFactoryWithOptions); parser->setPackageDirs(packageDirs); if (!parser->parseXMLFile(filename)) { reportError("ModelLoader", "loadModelFromFile", "Error in parsing model from URDF."); @@ -106,9 +108,12 @@ namespace iDynTree { // Allocate parser std::shared_ptr parser = std::make_shared(); - parser->setDocumentFactory([](XMLParserState& state){ - return std::shared_ptr(new URDFDocument(state)); - }); + auto parserOptions = this->m_pimpl->m_options; + auto documentFactoryWithOptions = [parserOptions](XMLParserState& state){ + return std::shared_ptr(new URDFDocument(state, parserOptions)); + }; + + parser->setDocumentFactory(documentFactoryWithOptions); parser->setPackageDirs(packageDirs); if (!parser->parseXMLString(modelString)) { reportError("ModelLoader", "loadModelFromString", "Error in parsing model from URDF."); diff --git a/src/model_io/codecs/src/URDFDocument.cpp b/src/model_io/codecs/src/URDFDocument.cpp index a23333a1dc..8540d53d2d 100644 --- a/src/model_io/codecs/src/URDFDocument.cpp +++ b/src/model_io/codecs/src/URDFDocument.cpp @@ -27,8 +27,8 @@ namespace iDynTree { const std::unordered_map& materialDatabase, ModelSolidShapes &modelGeometries); - URDFDocument::URDFDocument(XMLParserState& parserState) - : XMLDocument(parserState) {} + URDFDocument::URDFDocument(XMLParserState& parserState, const iDynTree::ModelParserOptions& options) + : XMLDocument(parserState), m_options(options) {} iDynTree::ModelParserOptions& URDFDocument::options() { return m_options; } diff --git a/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp b/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp index d5333d2188..c2ab1794cd 100644 --- a/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp +++ b/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp @@ -255,6 +255,59 @@ void checkDuplicateJointsReturnsError() { } +void checkaddSensorFramesAsAdditionalFramesOption() { + std::string urdf = R"( + + + + + + + + + + + + + + + + + + + + + + sensor + child_to_parent + + + + +)"; + + // Let's first load with the option disabled + { + iDynTree::ModelLoader mdlLoader; + iDynTree::ModelParserOptions parserOptions; + parserOptions.addSensorFramesAsAdditionalFrames = false; + mdlLoader.setParsingOptions(parserOptions); + ASSERT_IS_TRUE(mdlLoader.loadModelFromString(urdf)); + ASSERT_IS_FALSE(mdlLoader.model().isFrameNameUsed("l_leg_ft")); + } + + // Then with the option enabled + { + iDynTree::ModelLoader mdlLoader; + iDynTree::ModelParserOptions parserOptions; + parserOptions.addSensorFramesAsAdditionalFrames = true; + mdlLoader.setParsingOptions(parserOptions); + ASSERT_IS_TRUE(mdlLoader.loadModelFromString(urdf)); + ASSERT_IS_TRUE(mdlLoader.model().isFrameNameUsed("l_leg_ft")); + } + +} + int main() { checkURDF(getAbsModelPath("/simple_model.urdf"),1,0,0,1, 1, 0, "link1"); @@ -270,6 +323,7 @@ int main() checkLimitsForJointsAreDefinedFromFileName(getAbsModelPath("iCubGenova02.urdf")); checkLoadReducedModelOrderIsKept(getAbsModelPath("iCubGenova02.urdf")); + checkaddSensorFramesAsAdditionalFramesOption(); return EXIT_SUCCESS; }