1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0024463: BRepAlgo_Section::Build hangs

Added test case bugs/modalg_5/bug24463
This commit is contained in:
pkv 2013-12-26 15:47:44 +04:00 committed by bugmaster
parent ceaa5e27eb
commit 9c06009aa5
2 changed files with 31 additions and 5 deletions

View File

@ -34,6 +34,7 @@
#include <BRep_TEdge.hxx>
#include <TColgp_SequenceOfPnt2d.hxx>
#include <TColStd_SequenceOfReal.hxx>
#include <TColStd_Array1OfReal.hxx>
#include <TColGeom2d_SequenceOfCurve.hxx>
#include <TopTools_SequenceOfShape.hxx>
#include <Precision.hxx>
@ -176,9 +177,23 @@ void BRepTools::AddUVBounds(const TopoDS_Face& F,
gp_Pnt2d Pa,Pb,Pc;
Standard_Real i, nbp = 20;
Standard_Integer i, j, k, nbp = 20;
if (PC.GetType() == GeomAbs_Line) nbp = 2;
Standard_Real step = (pl - pf) / nbp;
Standard_Integer NbIntC1 = PC.NbIntervals(GeomAbs_C1);
if (NbIntC1 > 1)
nbp = 10;
TColStd_Array1OfReal SharpPoints(1, NbIntC1+1);
PC.Intervals(SharpPoints, GeomAbs_C1);
TColStd_Array1OfReal Parameters(1, nbp*NbIntC1+1);
k = 1;
for (i = 1; i <= NbIntC1; i++)
{
Standard_Real delta = (SharpPoints(i+1) - SharpPoints(i))/nbp;
for (j = 0; j < nbp; j++)
Parameters(k++) = SharpPoints(i) + j*delta;
}
Parameters(nbp*NbIntC1+1) = SharpPoints(NbIntC1+1);
gp_Pnt2d P;
PC.D0(pf,P);
Baux.Add(P);
@ -187,11 +202,11 @@ void BRepTools::AddUVBounds(const TopoDS_Face& F,
Standard_Real dv=0.0;
Pc=P;
for (i = 1; i < nbp; i++) {
pf += step;
for (i = 2; i < Parameters.Upper(); i++) {
pf = Parameters(i);
PC.D0(pf,P);
Baux.Add(P);
if(i==1) { Pb=Pc; Pc=P; }
if(i==2) { Pb=Pc; Pc=P; }
else {
//-- Calcul de la fleche
Pa=Pb; Pb=Pc; Pc=P;

View File

@ -0,0 +1,11 @@
puts "============"
puts "OCC24463"
puts "============"
puts ""
####################################
# BRepAlgo_Section::Build hangs
####################################
restore [locate_data_file bug24463_TK0000000000480_109.brep] a
plane p 0 7000 0 0 -1 0 0 0 -1
psection r a p