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:
parent
437ef7713e
commit
6b121e2b48
@ -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 ;
|
||||||
|
@ -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(),
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user