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

0030584: Modeling Algorithms, BRepFill_OffsetWire - access violation on Face having no boundaries

Added missing NULL and empty result checks.
Updated test cases using offset_wire_092.brep shape containing all Edges
with TopAbs_INTERNAL orientation (hense no boundary to make offset).
This commit is contained in:
kgv 2019-03-16 13:22:47 +03:00 committed by apn
parent 437ef7713e
commit 6b121e2b48
9 changed files with 56 additions and 53 deletions

View File

@ -238,19 +238,27 @@ static Standard_Boolean KPartCircle
BRepFill_IndexedDataMapOfOrientedShapeListOfShape& myMap, BRepFill_IndexedDataMapOfOrientedShapeListOfShape& myMap,
Standard_Boolean& myIsDone) Standard_Boolean& myIsDone)
{ {
TopExp_Explorer exp(mySpine,TopAbs_EDGE); TopoDS_Edge E;
Standard_Integer NbEdges = 0; for (TopExp_Explorer anEdgeIter (mySpine, TopAbs_EDGE); anEdgeIter.More(); anEdgeIter.Next())
TopoDS_Edge E; {
if (!E.IsNull())
for (; exp.More(); exp.Next()) { {
NbEdges++; return Standard_False;
E = TopoDS::Edge(exp.Current()); }
if (NbEdges > 1) return Standard_False; E = TopoDS::Edge (anEdgeIter.Current());
}
if (E.IsNull())
{
return Standard_False;
} }
Standard_Real f,l; Standard_Real f,l;
TopLoc_Location L; TopLoc_Location L;
Handle(Geom_Curve) C = BRep_Tool::Curve(E,L,f,l); Handle(Geom_Curve) C = BRep_Tool::Curve(E,L,f,l);
if (C.IsNull())
{
return Standard_False;
}
if (C->IsKind(STANDARD_TYPE(Geom_TrimmedCurve))) { if (C->IsKind(STANDARD_TYPE(Geom_TrimmedCurve))) {
Handle(Geom_TrimmedCurve) Ct = Handle(Geom_TrimmedCurve)::DownCast(C); Handle(Geom_TrimmedCurve) Ct = Handle(Geom_TrimmedCurve)::DownCast(C);
@ -741,7 +749,6 @@ void BRepFill_OffsetWire::PerformWithBiLo
return; return;
BRep_Builder myBuilder; BRep_Builder myBuilder;
myBuilder.MakeCompound(TopoDS::Compound(myShape));
//--------------------------------------------------------------------- //---------------------------------------------------------------------
// MapNodeVertex : associate to each node of the map (key1) and to // MapNodeVertex : associate to each node of the map (key1) and to
@ -785,6 +792,11 @@ void BRepFill_OffsetWire::PerformWithBiLo
TopExp::Vertices(theWire, Ends[0], Ends[1]); TopExp::Vertices(theWire, Ends[0], Ends[1]);
} }
if (Locus.NumberOfContours() == 0)
{
return;
}
for (Standard_Integer ic = 1; ic <= Locus.NumberOfContours(); ic++) { for (Standard_Integer ic = 1; ic <= Locus.NumberOfContours(); ic++) {
TopoDS_Shape PEE = Link.GeneratingShape(Locus.BasicElt(ic,Locus.NumberOfElts(ic))); TopoDS_Shape PEE = Link.GeneratingShape(Locus.BasicElt(ic,Locus.NumberOfElts(ic)));
TopoDS_Shape& PE = PEE ; TopoDS_Shape& PE = PEE ;

View File

@ -70,7 +70,12 @@ void BRepMAT2d_BisectingLocus::Compute(BRepMAT2d_Explorer& anExplo,
Standard_Integer i; Standard_Integer i;
nbSect.Clear(); nbSect.Clear();
theGraph = new MAT_Graph();
nbContours = anExplo.NumberOfContours(); nbContours = anExplo.NumberOfContours();
if (nbContours == 0)
{
return;
}
//--------------------------------- //---------------------------------
// Lecture des donnees de anExplo. // Lecture des donnees de anExplo.
@ -121,7 +126,6 @@ void BRepMAT2d_BisectingLocus::Compute(BRepMAT2d_Explorer& anExplo,
TheRoots->BackAdd(TheMAT.Bisector()); TheRoots->BackAdd(TheMAT.Bisector());
} }
theGraph = new MAT_Graph();
theGraph->Perform(TheMAT.SemiInfinite(), theGraph->Perform(TheMAT.SemiInfinite(),
TheRoots, TheRoots,
theTool.NumberOfItems(), theTool.NumberOfItems(),

View File

@ -123,12 +123,6 @@ void BRepMAT2d_Explorer::Add(const TopoDS_Wire& Spine,
const TopoDS_Face& aFace, const TopoDS_Face& aFace,
TopoDS_Face& aNewFace) TopoDS_Face& aNewFace)
{ {
// Modified by Sergey KHROMOV - Tue Nov 26 14:25:46 2002 Begin
// This method is totally rewroted to include check
// of connection and creation of a new spine.
NewContour();
myIsClosed(currentContour) = (Spine.Closed()) ? Standard_True : Standard_False;
// Modified by skv - Wed Jun 23 12:23:01 2004 Integration Begin // Modified by skv - Wed Jun 23 12:23:01 2004 Integration Begin
// Taking into account side of bisecting loci construction. // Taking into account side of bisecting loci construction.
// TopoDS_Wire aWFwd = TopoDS::Wire(Spine.Oriented(TopAbs_FORWARD)); // TopoDS_Wire aWFwd = TopoDS::Wire(Spine.Oriented(TopAbs_FORWARD));
@ -136,10 +130,15 @@ void BRepMAT2d_Explorer::Add(const TopoDS_Wire& Spine,
BRepTools_WireExplorer anExp(Spine, aFace); BRepTools_WireExplorer anExp(Spine, aFace);
// Modified by skv - Wed Jun 23 12:23:02 2004 Integration End // Modified by skv - Wed Jun 23 12:23:02 2004 Integration End
TopTools_IndexedDataMapOfShapeShape anOldNewE; TopTools_IndexedDataMapOfShapeShape anOldNewE;
if (!anExp.More()) if (!anExp.More())
return; return;
// Modified by Sergey KHROMOV - Tue Nov 26 14:25:46 2002 Begin
// This method is totally rewroted to include check
// of connection and creation of a new spine.
NewContour();
myIsClosed(currentContour) = (Spine.Closed()) ? Standard_True : Standard_False;
TopoDS_Edge aFirstEdge = anExp.Current(); TopoDS_Edge aFirstEdge = anExp.Current();
TopoDS_Edge aPrevEdge = aFirstEdge; TopoDS_Edge aPrevEdge = aFirstEdge;
Standard_Real UFirst,ULast, aD; Standard_Real UFirst,ULast, aD;

View File

@ -1,8 +1,7 @@
puts "TODO OCC23748 ALL: Error : The offset cannot be built." puts "Tested shape has no Face boundaries (all Edges have TopAbs_INTERNAL flag), therefore offset will NOT be created"
puts "TODO OCC23748 ALL: Error: The command cannot be built" puts "REQUIRED ALL: Error : The offset cannot be built."
puts "TODO OCC23748 Windows: Error: Offset is not done." puts "REQUIRED ALL: Error: The command cannot be built"
puts "TODO OCC23748 Linux: An exception was caught" puts "REQUIRED ALL: Error: Offset is not done."
puts "TODO OCC23748 Linux: \\*\\* Exception \\*\\*"
restore [locate_data_file offset_wire_092.brep] s restore [locate_data_file offset_wire_092.brep] s
@ -10,4 +9,3 @@ set length 0
set nbsh_v 0 set nbsh_v 0
set nbsh_e 0 set nbsh_e 0
set nbsh_w 0 set nbsh_w 0

View File

@ -1,8 +1,7 @@
puts "TODO OCC23748 ALL: Error : The offset cannot be built." puts "Tested shape has no Face boundaries (all Edges have TopAbs_INTERNAL flag), therefore offset will NOT be created"
puts "TODO OCC23748 ALL: Error: The command cannot be built" puts "REQUIRED ALL: Error : The offset cannot be built."
puts "TODO OCC23748 Windows: Error: Offset is not done." puts "REQUIRED ALL: Error: The command cannot be built"
puts "TODO OCC23748 Linux: An exception was caught" puts "REQUIRED ALL: Error: Offset is not done."
puts "TODO OCC23748 Linux: \\*\\* Exception \\*\\*"
restore [locate_data_file offset_wire_092.brep] s restore [locate_data_file offset_wire_092.brep] s
@ -10,4 +9,3 @@ set length 0
set nbsh_v 0 set nbsh_v 0
set nbsh_e 0 set nbsh_e 0
set nbsh_w 0 set nbsh_w 0

View File

@ -1,8 +1,7 @@
puts "TODO OCC23748 ALL: Error : The offset cannot be built." puts "Tested shape has no Face boundaries (all Edges have TopAbs_INTERNAL flag), therefore offset will NOT be created"
puts "TODO OCC23748 ALL: Error: The command cannot be built" puts "REQUIRED ALL: Error : The offset cannot be built."
puts "TODO OCC23748 Windows: Error: Offset is not done." puts "REQUIRED ALL: Error: The command cannot be built"
puts "TODO OCC23748 Linux: An exception was caught" puts "REQUIRED ALL: Error: Offset is not done."
puts "TODO OCC23748 Linux: \\*\\* Exception \\*\\*"
restore [locate_data_file offset_wire_092.brep] s restore [locate_data_file offset_wire_092.brep] s
@ -10,4 +9,3 @@ set length 0
set nbsh_v 0 set nbsh_v 0
set nbsh_e 0 set nbsh_e 0
set nbsh_w 0 set nbsh_w 0

View File

@ -1,8 +1,7 @@
puts "TODO OCC23748 ALL: Error : The offset cannot be built." puts "Tested shape has no Face boundaries (all Edges have TopAbs_INTERNAL flag), therefore offset will NOT be created"
puts "TODO OCC23748 ALL: Error: The command cannot be built" puts "REQUIRED ALL: Error : The offset cannot be built."
puts "TODO OCC23748 Windows: Error: Offset is not done." puts "REQUIRED ALL: Error: The command cannot be built"
puts "TODO OCC23748 Linux: An exception was caught" puts "REQUIRED ALL: Error: Offset is not done."
puts "TODO OCC23748 Linux: \\*\\* Exception \\*\\*"
restore [locate_data_file offset_wire_092.brep] s restore [locate_data_file offset_wire_092.brep] s
@ -10,4 +9,3 @@ set length 0
set nbsh_v 0 set nbsh_v 0
set nbsh_e 0 set nbsh_e 0
set nbsh_w 0 set nbsh_w 0

View File

@ -1,8 +1,7 @@
puts "TODO OCC23748 ALL: Error : The offset cannot be built." puts "Tested shape has no Face boundaries (all Edges have TopAbs_INTERNAL flag), therefore offset will NOT be created"
puts "TODO OCC23748 ALL: Error: The command cannot be built" puts "REQUIRED ALL: Error : The offset cannot be built."
puts "TODO OCC23748 Windows: Error: Offset is not done." puts "REQUIRED ALL: Error: The command cannot be built"
puts "TODO OCC23748 Linux: An exception was caught" puts "REQUIRED ALL: Error: Offset is not done."
puts "TODO OCC23748 Linux: \\*\\* Exception \\*\\*"
restore [locate_data_file offset_wire_092.brep] s restore [locate_data_file offset_wire_092.brep] s
@ -10,4 +9,3 @@ set length 0
set nbsh_v 0 set nbsh_v 0
set nbsh_e 0 set nbsh_e 0
set nbsh_w 0 set nbsh_w 0

View File

@ -1,8 +1,7 @@
puts "TODO OCC23748 ALL: Error : The offset cannot be built." puts "Tested shape has no Face boundaries (all Edges have TopAbs_INTERNAL flag), therefore offset will NOT be created"
puts "TODO OCC23748 ALL: Error: The command cannot be built" puts "REQUIRED ALL: Error : The offset cannot be built."
puts "TODO OCC23748 Windows: Error: Offset is not done." puts "REQUIRED ALL: Error: The command cannot be built"
puts "TODO OCC23748 Linux: An exception was caught" puts "REQUIRED ALL: Error: Offset is not done."
puts "TODO OCC23748 Linux: \\*\\* Exception \\*\\*"
restore [locate_data_file offset_wire_092.brep] s restore [locate_data_file offset_wire_092.brep] s
@ -10,4 +9,3 @@ set length 0
set nbsh_v 0 set nbsh_v 0
set nbsh_e 0 set nbsh_e 0
set nbsh_w 0 set nbsh_w 0