From 983e35ed71b95137772111751ad41a5da4937005 Mon Sep 17 00:00:00 2001 From: ichesnok Date: Tue, 12 Mar 2024 18:01:09 +0000 Subject: [PATCH] 0033410: Data Exchange, Step Import - TRIANGULATED_FACE from STEP where there are no pnval entries Problem fixed by using array of nodes in case when aPnindices is empty. --- src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx | 12 +++++++----- tests/bugs/step/bug33410 | 12 ++++++++++++ 2 files changed, 19 insertions(+), 5 deletions(-) create mode 100644 tests/bugs/step/bug33410 diff --git a/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx b/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx index 93539a1aef..c33ac4a3bd 100644 --- a/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx +++ b/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx @@ -105,12 +105,13 @@ namespace { // ============================================================================ static void SetNodes(const Handle(Poly_Triangulation)& theMesh, Handle(TColgp_HArray1OfXYZ)& theNodes, + const Standard_Integer theNumPnindex, Handle(TColStd_HArray1OfInteger)& thePnindices, const Standard_Real theLengthFactor) { for (Standard_Integer aPnIndex = 1; aPnIndex <= theMesh->NbNodes(); ++aPnIndex) { - const gp_XYZ& aPoint = theNodes->Value(thePnindices->Value(aPnIndex)); + const gp_XYZ& aPoint = theNodes->Value((theNumPnindex > 0) ? thePnindices->Value(aPnIndex) : aPnIndex); theMesh->SetNode(aPnIndex, theLengthFactor * aPoint); } } @@ -326,10 +327,11 @@ namespace { const Standard_Boolean aHasUVNodes = Standard_False; const Standard_Boolean aHasNormals = (aNormNum > 0); + const Standard_Integer aNbNodes = (aNumPnindex > 0) ? aNumPnindex : aNodes->Length(); if (aTrianStripsNum == 0 && aTrianFansNum == 0) { - aMesh = new Poly_Triangulation(aNumPnindex, aTrianNum, aHasUVNodes, aHasNormals); + aMesh = new Poly_Triangulation(aNbNodes, aTrianNum, aHasUVNodes, aHasNormals); } else { @@ -359,14 +361,14 @@ namespace { aNbTriaFans += aTriangleFan->Length() - 2; } - aMesh = new Poly_Triangulation(aNumPnindex, aNbTriaStrips + aNbTriaFans, aHasUVNodes, aHasNormals); + aMesh = new Poly_Triangulation(aNbNodes, aNbTriaStrips + aNbTriaFans, aHasUVNodes, aHasNormals); } - SetNodes(aMesh, aNodes, aPnindices, theLocalFactors.LengthFactor()); + SetNodes(aMesh, aNodes, aNumPnindex, aPnindices, theLocalFactors.LengthFactor()); if (aHasNormals) { - SetNormals(aMesh, aNormals, aNormNum, aNumPnindex); + SetNormals(aMesh, aNormals, aNormNum, aNbNodes); } SetTriangles(aMesh, aTriangles, aTrianStripsNum, aTriaStrips, aTrianFansNum, aTriaFans); diff --git a/tests/bugs/step/bug33410 b/tests/bugs/step/bug33410 new file mode 100644 index 0000000000..441b389140 --- /dev/null +++ b/tests/bugs/step/bug33410 @@ -0,0 +1,12 @@ +puts "========================" +puts "0033410: Data Exchange, Step Import - TRIANGULATED_FACE from STEP where there are no pnval entries" +puts "========================" + +pload OCAF + +# Read file +ReadStep D [locate_data_file bug33410.step] +XGetOneShape sh D +checktrinfo sh -face 1 -nod 81 -tri 128 + +Close D