From 7642e2d02d474e870c1060b0de2a92d5b4d1852f Mon Sep 17 00:00:00 2001 From: isn Date: Thu, 27 Aug 2015 13:52:14 +0300 Subject: [PATCH] 0026498: BRepOffsetAPI_MakeOffset causes segmentation fault Test case for issue CR26498 --- src/BRepFill/BRepFill_OffsetWire.cxx | 19 +++++++++++++ tests/bugs/modalg_6/bug26498 | 42 ++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100755 tests/bugs/modalg_6/bug26498 diff --git a/src/BRepFill/BRepFill_OffsetWire.cxx b/src/BRepFill/BRepFill_OffsetWire.cxx index e644d9d9cc..7aaf944a23 100644 --- a/src/BRepFill/BRepFill_OffsetWire.cxx +++ b/src/BRepFill/BRepFill_OffsetWire.cxx @@ -222,6 +222,8 @@ static void MakeOffset const GeomAbs_JoinType theJoinType, const TopoDS_Vertex * Ends); +Standard_Boolean CheckSmallParamOnEdge(const TopoDS_Edge& anEdge); + //======================================================================= //function : KPartCircle //purpose : @@ -1379,6 +1381,8 @@ void BRepFill_OffsetWire::MakeWires() TopExp::Vertices (E,V1,V2); if (V1.IsSame(V2) && IsSmallClosedEdge(E, V1)) continue; //remove small closed edges + if (!CheckSmallParamOnEdge(E)) + continue; if (!MVE.Contains(V1)) { TopTools_ListOfShape 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; +} + + diff --git a/tests/bugs/modalg_6/bug26498 b/tests/bugs/modalg_6/bug26498 new file mode 100755 index 0000000000..864859f76d --- /dev/null +++ b/tests/bugs/modalg_6/bug26498 @@ -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