mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0026568: Modeling Algorithms - Exception when creating pipe
BRepFill_Pipe.cxx: protection against wrong shape type is added GeomFill_Sweep.cxx: protection against using 0-vector to create Direction is added bug26568: test script is corrected: "TODO ..." is removed
This commit is contained in:
parent
f3269ef5f1
commit
ce9aefc8aa
@ -760,8 +760,11 @@ TopoDS_Shape BRepFill_Pipe::MakeShape(const TopoDS_Shape& S,
|
||||
TopoDS_Face F;
|
||||
for (ii=InitialLength+1; ii<=myFaces->ColLength(); ii++) {
|
||||
for (jj=1; jj<=myFaces->RowLength(); jj++) {
|
||||
F = TopoDS::Face(myFaces->Value(ii, jj));
|
||||
if (!F.IsNull()) B.Add(result, F);
|
||||
if (myFaces->Value(ii, jj).ShapeType() == TopAbs_FACE)
|
||||
{
|
||||
F = TopoDS::Face(myFaces->Value(ii, jj));
|
||||
if (!F.IsNull()) B.Add(result, F);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -953,7 +953,12 @@ static Standard_Boolean IsSweepParallelSpine (const Handle(GeomFill_LocationLaw)
|
||||
// (2.2.a) Cylindre
|
||||
// si la line est orthogonale au plan de rotation
|
||||
SError = error;
|
||||
gp_Ax3 Axis(CentreOfSurf, Dir.Direction(), DS);
|
||||
//
|
||||
gp_Ax3 Axis(CentreOfSurf, Dir.Direction());
|
||||
if (DS.SquareMagnitude() > gp::Resolution())
|
||||
{
|
||||
Axis.SetXDirection(DS);
|
||||
}
|
||||
S = new (Geom_CylindricalSurface)
|
||||
(Axis, L.Distance(CentreOfSurf));
|
||||
Ok = Standard_True;
|
||||
|
@ -1,10 +1,6 @@
|
||||
puts "TODO OCC26568 ALL: An exception was caught"
|
||||
puts "TODO OCC26568 ALL: \\*\\* Exception \\*\\*.*"
|
||||
puts "TODO OCC26568 ALL: TEST INCOMPLETE"
|
||||
|
||||
puts "========"
|
||||
puts "OCC26568"
|
||||
puts "========"
|
||||
puts "============================================================="
|
||||
puts "OCC26568 - Modeling Algorithms - Crash when creating pipe"
|
||||
puts "============================================================="
|
||||
puts ""
|
||||
################################
|
||||
# Exception when creating pipe
|
||||
@ -15,4 +11,14 @@ explode b f
|
||||
circle c 0 0 0 0 1 0 10
|
||||
mkedge e c
|
||||
wire w e
|
||||
pipe p w b_1
|
||||
pipe result w b_1
|
||||
|
||||
checkshape result
|
||||
|
||||
checknbshapes result -solid 1 -shell 1 -face 3 -wire 3 -edge 7 -vertex 4
|
||||
|
||||
set tolres [checkmaxtol result]
|
||||
|
||||
if { ${tolres} > 2.e-7} {
|
||||
puts "Error: bad tolerance of result"
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user