mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0026498: BRepOffsetAPI_MakeOffset causes segmentation fault
Test case for issue CR26498
This commit is contained in:
parent
e43a4f2bd9
commit
7642e2d02d
@ -222,6 +222,8 @@ static void MakeOffset
|
|||||||
const GeomAbs_JoinType theJoinType,
|
const GeomAbs_JoinType theJoinType,
|
||||||
const TopoDS_Vertex * Ends);
|
const TopoDS_Vertex * Ends);
|
||||||
|
|
||||||
|
Standard_Boolean CheckSmallParamOnEdge(const TopoDS_Edge& anEdge);
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
//function : KPartCircle
|
//function : KPartCircle
|
||||||
//purpose :
|
//purpose :
|
||||||
@ -1379,6 +1381,8 @@ void BRepFill_OffsetWire::MakeWires()
|
|||||||
TopExp::Vertices (E,V1,V2);
|
TopExp::Vertices (E,V1,V2);
|
||||||
if (V1.IsSame(V2) && IsSmallClosedEdge(E, V1))
|
if (V1.IsSame(V2) && IsSmallClosedEdge(E, V1))
|
||||||
continue; //remove small closed edges
|
continue; //remove small closed edges
|
||||||
|
if (!CheckSmallParamOnEdge(E))
|
||||||
|
continue;
|
||||||
if (!MVE.Contains(V1)) {
|
if (!MVE.Contains(V1)) {
|
||||||
TopTools_ListOfShape empty;
|
TopTools_ListOfShape empty;
|
||||||
MVE.Add(V1,empty);
|
MVE.Add(V1,empty);
|
||||||
@ -2756,3 +2760,18 @@ static void QuasiFleche(const Adaptor3d_Curve& C,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Standard_Boolean CheckSmallParamOnEdge(const TopoDS_Edge& anEdge)
|
||||||
|
{
|
||||||
|
const BRep_ListOfCurveRepresentation& aList = ((Handle(BRep_TEdge)::DownCast(anEdge.TShape()))->Curves());
|
||||||
|
if (!aList.IsEmpty())
|
||||||
|
{
|
||||||
|
Handle( BRep_CurveRepresentation ) CRep = ((Handle(BRep_TEdge)::DownCast(anEdge.TShape()))->Curves()).First();
|
||||||
|
Standard_Real f = (Handle(BRep_GCurve)::DownCast(CRep))->First();
|
||||||
|
Standard_Real l = (Handle(BRep_GCurve)::DownCast(CRep))->Last();
|
||||||
|
if (Abs (l - f) < Precision::PConfusion())
|
||||||
|
return Standard_False;
|
||||||
|
}
|
||||||
|
return Standard_True;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
42
tests/bugs/modalg_6/bug26498
Executable file
42
tests/bugs/modalg_6/bug26498
Executable file
@ -0,0 +1,42 @@
|
|||||||
|
puts "============"
|
||||||
|
puts "OCC26498"
|
||||||
|
puts "============"
|
||||||
|
puts ""
|
||||||
|
#######################################################################
|
||||||
|
# BRepOffsetAPI_MakeOffset causes segmentation fault
|
||||||
|
#######################################################################
|
||||||
|
|
||||||
|
polyline w 0 0 0 0.2 0 0 0.2 0.2 0 0.4 0.2 0 0.4 0.4 0 -0.06 0.57 0
|
||||||
|
|
||||||
|
smallview
|
||||||
|
display w
|
||||||
|
fit
|
||||||
|
|
||||||
|
if [catch { openoffset r w 1 -0.2 i } ] {
|
||||||
|
puts "Error : openoffset is wrong"
|
||||||
|
} else {
|
||||||
|
renamevar r_1 result
|
||||||
|
|
||||||
|
set length 0.272485
|
||||||
|
|
||||||
|
set nbshapes_expected "
|
||||||
|
Number of shapes in shape
|
||||||
|
VERTEX : 3
|
||||||
|
EDGE : 2
|
||||||
|
WIRE : 1
|
||||||
|
FACE : 0
|
||||||
|
SHELL : 0
|
||||||
|
SOLID : 0
|
||||||
|
COMPSOLID : 0
|
||||||
|
COMPOUND : 0
|
||||||
|
SHAPE : 6
|
||||||
|
"
|
||||||
|
checknbshapes result -ref ${nbshapes_expected} -t -m "Offset"
|
||||||
|
|
||||||
|
checkshape result
|
||||||
|
|
||||||
|
display result
|
||||||
|
fit
|
||||||
|
}
|
||||||
|
|
||||||
|
set only_screen_axo 1
|
Loading…
x
Reference in New Issue
Block a user