mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0032692: Mesh - In BRepMesh_ModelPreProcessor avoid crashes with problematic topology
Improved the processing for the case where Failure flag for the meshing face is set. Specific tests added. Check triangulation consistency even for shapes with problematic topology given that they are suitable for keeping it.
This commit is contained in:
parent
aaa03c1efb
commit
1593d38b13
@ -46,7 +46,8 @@ namespace
|
||||
void operator()(const Standard_Integer theFaceIndex) const
|
||||
{
|
||||
const IMeshData::IFaceHandle& aDFace = myModel->GetFace(theFaceIndex);
|
||||
if (aDFace->IsSet(IMeshData_Outdated))
|
||||
if (aDFace->IsSet(IMeshData_Outdated) ||
|
||||
aDFace->GetFace().IsNull())
|
||||
{
|
||||
return;
|
||||
}
|
||||
@ -119,7 +120,7 @@ namespace
|
||||
void operator()(const Standard_Integer theFaceIndex) const
|
||||
{
|
||||
const IMeshData::IFaceHandle& aDFace = myModel->GetFace(theFaceIndex);
|
||||
if (aDFace->GetSurface()->GetType() != GeomAbs_Cone)
|
||||
if (aDFace->GetSurface()->GetType() != GeomAbs_Cone || aDFace->IsSet(IMeshData_Failure))
|
||||
{
|
||||
return;
|
||||
}
|
||||
@ -128,7 +129,7 @@ namespace
|
||||
for (Standard_Integer aEdgeIdx = 0; aEdgeIdx < aDWire->EdgesNb() - 1; ++aEdgeIdx)
|
||||
{
|
||||
const IMeshData::IEdgePtr& aDEdge = aDWire->GetEdge (aEdgeIdx);
|
||||
|
||||
|
||||
if (aDEdge->GetPCurve(aDFace.get(), TopAbs_FORWARD) != aDEdge->GetPCurve(aDFace.get(), TopAbs_REVERSED))
|
||||
{
|
||||
if (aDEdge->GetCurve()->ParametersNb() == 2)
|
||||
@ -146,7 +147,7 @@ namespace
|
||||
}
|
||||
}
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
11
tests/bugs/mesh/bug32692_1
Normal file
11
tests/bugs/mesh/bug32692_1
Normal file
@ -0,0 +1,11 @@
|
||||
puts "========="
|
||||
puts "OCC32692: Crash when the input shape has some invalid topology"
|
||||
puts "========="
|
||||
puts ""
|
||||
|
||||
puts "REQUIRED ALL: Meshing statuses: SelfIntersectingWire Failure"
|
||||
|
||||
restore [locate_data_file bug32692.brep] s
|
||||
incmesh s 0.01 -parallel
|
||||
|
||||
checktrinfo s -nod 7511 -tri 7625 -empty 9 -face 309
|
11
tests/bugs/mesh/bug32692_2
Normal file
11
tests/bugs/mesh/bug32692_2
Normal file
@ -0,0 +1,11 @@
|
||||
puts "========="
|
||||
puts "OCC32692: Crash when the input shape has some invalid topology"
|
||||
puts "========="
|
||||
puts ""
|
||||
|
||||
puts "REQUIRED ALL: Meshing statuses: Reused"
|
||||
|
||||
restore [locate_data_file bug32692_broken_mesh.brep] s
|
||||
incmesh s 0.01 -parallel
|
||||
|
||||
checktrinfo s -nod 3 -tri 1 -face 1
|
14
tests/bugs/mesh/bug32692_3
Normal file
14
tests/bugs/mesh/bug32692_3
Normal file
@ -0,0 +1,14 @@
|
||||
puts "========="
|
||||
puts "OCC32692: Crash when the input shape has some invalid topology"
|
||||
puts "========="
|
||||
puts ""
|
||||
|
||||
puts "REQUIRED ALL: Meshing statuses: OpenWire Failure Outdated"
|
||||
|
||||
pload MODELING
|
||||
cylinder c 0 0 0 10
|
||||
mkface f c
|
||||
|
||||
incmesh f 0.01 -parallel
|
||||
|
||||
checktrinfo f -nod 0 -tri 0 -face 1
|
Loading…
x
Reference in New Issue
Block a user