mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0024949: Segmentation Violation during pipe creation
Test cases for issue 0024949 Correction of test case for issue CR24949
This commit is contained in:
parent
95a2cf2f74
commit
73920cd481
@ -72,6 +72,9 @@ is
|
||||
---C++ : return const &
|
||||
is static;
|
||||
|
||||
ErrorOnSurface (me)
|
||||
returns Real from Standard;
|
||||
|
||||
FirstShape(me) returns Shape from TopoDS
|
||||
---C++ : return const &
|
||||
is static;
|
||||
@ -185,4 +188,6 @@ fields
|
||||
myMode : Trihedron from GeomFill;
|
||||
myForceApproxC1 : Boolean from Standard;
|
||||
|
||||
myErrorOnSurf : Real from Standard;
|
||||
|
||||
end Pipe;
|
||||
|
@ -363,6 +363,16 @@ const TopoDS_Shape& BRepFill_Pipe::Shape() const
|
||||
return myShape;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : ErrorOnSurface
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
|
||||
Standard_Real BRepFill_Pipe::ErrorOnSurface() const
|
||||
{
|
||||
return myErrorOnSurf;
|
||||
}
|
||||
|
||||
|
||||
//=======================================================================
|
||||
//function : FirstShape
|
||||
@ -521,6 +531,7 @@ TopoDS_Wire BRepFill_Pipe::PipeLine(const gp_Pnt& Point)
|
||||
MkSw.Build( myReversedEdges, myTapes, myRails,
|
||||
BRepFill_Modified, myContinuity, GeomFill_Location, myDegmax, mySegmax );
|
||||
TopoDS_Shape aLocalShape = MkSw.Shape();
|
||||
myErrorOnSurf = MkSw.ErrorOnSurface();
|
||||
return TopoDS::Wire(aLocalShape);
|
||||
// return TopoDS::Wire(MkSw.Shape());
|
||||
}
|
||||
@ -648,6 +659,7 @@ TopoDS_Shape BRepFill_Pipe::MakeShape(const TopoDS_Shape& S,
|
||||
MkSw.Build( myReversedEdges, myTapes, myRails,
|
||||
BRepFill_Modified, myContinuity, GeomFill_Location, myDegmax, mySegmax );
|
||||
result = MkSw.Shape();
|
||||
myErrorOnSurf = MkSw.ErrorOnSurface();
|
||||
|
||||
Handle(TopTools_HArray2OfShape) aSections = MkSw.Sections();
|
||||
|
||||
@ -669,6 +681,7 @@ TopoDS_Shape BRepFill_Pipe::MakeShape(const TopoDS_Shape& S,
|
||||
MkSw.Build( myReversedEdges, myTapes, myRails,
|
||||
BRepFill_Modified, myContinuity, GeomFill_Location, myDegmax, mySegmax );
|
||||
result = MkSw.Shape();
|
||||
myErrorOnSurf = MkSw.ErrorOnSurface();
|
||||
//Correct <myFirst> and <myLast>
|
||||
ReverseModifiedEdges(myFirst, myReversedEdges);
|
||||
ReverseModifiedEdges(myLast, myReversedEdges);
|
||||
|
@ -256,6 +256,9 @@ is
|
||||
returns Shape from TopoDS
|
||||
is static;
|
||||
|
||||
ErrorOnSurface (me)
|
||||
returns Real from Standard;
|
||||
|
||||
FirstShape (me)
|
||||
---Purpose: Returns the TopoDS Shape of the bottom of the sweep.
|
||||
---C++: return const &
|
||||
@ -316,6 +319,8 @@ fields
|
||||
myTrihedron : Trihedron from GeomFill;
|
||||
myTransition : TransitionStyle from BRepFill;
|
||||
myStatus : PipeError from GeomFill;
|
||||
myErrorOnSurf : Real from Standard;
|
||||
|
||||
end PipeShell;
|
||||
|
||||
|
||||
|
@ -773,6 +773,7 @@ void BRepFill_PipeShell::SetForceApproxC1(const Standard_Boolean ForceApproxC1)
|
||||
|
||||
if (Ok) {
|
||||
myShape = MkSw.Shape();
|
||||
myErrorOnSurf = MkSw.ErrorOnSurface();
|
||||
|
||||
TopoDS_Shape aBottomWire = myFirst;
|
||||
TopoDS_Shape aTopWire = myLast;
|
||||
@ -879,6 +880,16 @@ const TopoDS_Shape& BRepFill_PipeShell::Shape() const
|
||||
return myShape;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : ErrorOnSurface
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
|
||||
Standard_Real BRepFill_PipeShell::ErrorOnSurface() const
|
||||
{
|
||||
return myErrorOnSurf;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : FirstShape
|
||||
//purpose : Return the start section
|
||||
|
@ -2456,8 +2456,13 @@ BRepFill_Sweep::BRepFill_Sweep(const Handle(BRepFill_SectionLaw)& Section,
|
||||
Vertex(1,ipath+1),
|
||||
myTol3d);
|
||||
}
|
||||
else UpdateEdge(TopoDS::Edge(UEdge(isec, ipath)),
|
||||
else
|
||||
{
|
||||
if (UEdge(isec, ipath).IsNull()) //sweep failed
|
||||
return Standard_False;
|
||||
UpdateEdge(TopoDS::Edge(UEdge(isec, ipath)),
|
||||
S, !exuv, UFirst);
|
||||
}
|
||||
|
||||
if (uclose && (isec==NbLaw)) {
|
||||
UpdateEdge(TopoDS::Edge(UEdge(1, ipath)),
|
||||
|
@ -90,6 +90,11 @@ is
|
||||
returns Shape from TopoDS;
|
||||
|
||||
|
||||
ErrorOnSurface (me)
|
||||
---Level: Public
|
||||
returns Real from Standard;
|
||||
|
||||
|
||||
fields
|
||||
|
||||
myPipe : Pipe from BRepFill;
|
||||
|
@ -22,6 +22,8 @@
|
||||
#include <TopoDS_Vertex.hxx>
|
||||
#include <TopoDS.hxx>
|
||||
#include <TopAbs_ShapeEnum.hxx>
|
||||
#include <TopTools_IndexedMapOfShape.hxx>
|
||||
#include <TopExp.hxx>
|
||||
|
||||
//=======================================================================
|
||||
//function : BRepOffsetAPI_MakePipe
|
||||
@ -76,6 +78,12 @@ const BRepFill_Pipe& BRepOffsetAPI_MakePipe::Pipe() const
|
||||
void BRepOffsetAPI_MakePipe::Build()
|
||||
{
|
||||
myShape = myPipe.Shape();
|
||||
//Check for emptiness of result
|
||||
TopTools_IndexedMapOfShape theMap;
|
||||
TopExp::MapShapes(myShape, theMap);
|
||||
if (theMap.Extent() == 1)
|
||||
NotDone();
|
||||
else
|
||||
Done();
|
||||
}
|
||||
|
||||
@ -122,3 +130,12 @@ TopoDS_Shape BRepOffsetAPI_MakePipe::Generated (const TopoDS_Shape& SSpine,
|
||||
return bid;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : ErrorOnSurface
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
|
||||
Standard_Real BRepOffsetAPI_MakePipe::ErrorOnSurface() const
|
||||
{
|
||||
return myPipe.ErrorOnSurface();
|
||||
}
|
||||
|
@ -349,6 +349,9 @@ is
|
||||
returns ListOfShape from TopTools
|
||||
is redefined;
|
||||
|
||||
ErrorOnSurface (me)
|
||||
returns Real from Standard;
|
||||
|
||||
fields
|
||||
|
||||
myPipe : PipeShell from BRepFill;
|
||||
|
@ -305,3 +305,12 @@ BRepOffsetAPI_MakePipeShell::Generated(const TopoDS_Shape& S)
|
||||
return myGenerated;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : ErrorOnSurface
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
|
||||
Standard_Real BRepOffsetAPI_MakePipeShell::ErrorOnSurface() const
|
||||
{
|
||||
return myPipe->ErrorOnSurface();
|
||||
}
|
||||
|
31
tests/bugs/modalg_5/bug24949
Normal file
31
tests/bugs/modalg_5/bug24949
Normal file
@ -0,0 +1,31 @@
|
||||
puts "============"
|
||||
puts "OCC24949"
|
||||
puts "============"
|
||||
puts ""
|
||||
#######################################################################
|
||||
# Segmentation Violation during pipe creation
|
||||
#######################################################################
|
||||
|
||||
restore [locate_data_file bug24949_Comp.brep] c
|
||||
explode c
|
||||
mksweep c_1
|
||||
addsweep c_2
|
||||
catch {buildsweep res}
|
||||
|
||||
restore [locate_data_file bug24949_Comp.brep] c
|
||||
explode c
|
||||
pipe result c_1 c_2 2
|
||||
|
||||
set square 188.689
|
||||
|
||||
set nb_v_good 14
|
||||
set nb_e_good 19
|
||||
set nb_w_good 6
|
||||
set nb_f_good 6
|
||||
set nb_sh_good 1
|
||||
set nb_sol_good 0
|
||||
set nb_compsol_good 0
|
||||
set nb_compound_good 0
|
||||
set nb_shape_good 46
|
||||
|
||||
set 2dviewer 1
|
Loading…
x
Reference in New Issue
Block a user