1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00

0033009: Foundation Classes - Bnd_OBB::ReBuild() expects point array starting from 0

Add test. Update OBBTool constructor for any bounds of array of points.
This commit is contained in:
akondrat 2022-06-10 14:33:15 +03:00 committed by afokin
parent 714fb6b516
commit fb30026cf1
3 changed files with 29 additions and 1 deletions

View File

@ -419,7 +419,7 @@ OBBTool::
myPointBoxSet->SetSize(myPntsList.Length());
// Add the points into Set
for (Standard_Integer iP = 0; iP < theL.Length(); ++iP)
for (Standard_Integer iP = theL.Lower(); iP <= theL.Upper(); ++iP)
{
const gp_Pnt& aP = theL (iP);
Standard_Real aTol = theLT ? theLT->Value(iP) : Precision::Confusion();

View File

@ -4257,6 +4257,23 @@ static Standard_Integer OCC32744(Draw_Interpretor& theDi, Standard_Integer theNb
return 0;
}
static Standard_Integer OCC33009(Draw_Interpretor&, Standard_Integer, const char**)
{
Bnd_OBB aBndBox;
TColgp_Array1OfPnt aPoints(1, 5);
aPoints.ChangeValue(1) = gp_Pnt(1, 2, 3);
aPoints.ChangeValue(2) = gp_Pnt(3, 2, 1);
aPoints.ChangeValue(3) = gp_Pnt(2, 3, 1);
aPoints.ChangeValue(4) = gp_Pnt(1, 3, 2);
aPoints.ChangeValue(5) = gp_Pnt(2, 1, 3);
aBndBox.ReBuild(aPoints, (const TColStd_Array1OfReal*)0, true);
return 0;
}
//=======================================================================
//function : QACheckBends
//purpose :
@ -4427,6 +4444,10 @@ void QABugs::Commands_20(Draw_Interpretor& theCommands) {
__FILE__,
OCC32744, group);
theCommands.Add("OCC33009",
"Tests the case when",
__FILE__, OCC33009, group);
theCommands.Add("QACheckBends",
"QACheckBends curve [CosMaxAngle [theNbPoints]]",
__FILE__,

View File

@ -0,0 +1,7 @@
puts "============================================================================================="
puts "0033009: Foundation Classes - Bnd_OBB::ReBuild() expects point array starting from 0"
puts "============================================================================================="
puts ""
pload QAcommands
OCC33009