range-based for for TopExp_Explorer

This commit is contained in:
Joachim Schoeberl 2021-11-06 10:44:01 +01:00
parent 64e40a25e0
commit 14f32f73c0
2 changed files with 42 additions and 32 deletions

View File

@ -779,7 +779,6 @@ namespace netgen
void OCCGeometry :: BuildFMap() void OCCGeometry :: BuildFMap()
{ {
somap.Clear(); somap.Clear();
@ -881,7 +880,7 @@ namespace netgen
TopoDS_Face face = TopoDS::Face(exp2.Current()); TopoDS_Face face = TopoDS::Face(exp2.Current());
if (fmap.FindIndex(face) < 1) if (fmap.FindIndex(face) < 1)
{ {
fmap.Add (face); fmap.Add (face);
for (exp3.Init(face, TopAbs_WIRE); exp3.More(); exp3.Next()) for (exp3.Init(face, TopAbs_WIRE); exp3.More(); exp3.Next())
{ {
@ -913,39 +912,24 @@ namespace netgen
// Free Faces // Free Faces
for (auto face : MyExplorer(shape, TopAbs_FACE, TopAbs_SHELL))
for (exp2.Init(shape, TopAbs_FACE, TopAbs_SHELL); exp2.More(); exp2.Next()) if (fmap.FindIndex(face) < 1)
{ {
TopoDS_Face face = TopoDS::Face(exp2.Current());
if (fmap.FindIndex(face) < 1)
{
fmap.Add (face); fmap.Add (face);
for (auto wire : MyExplorer(face, TopAbs_WIRE))
for (exp3.Init(exp2.Current(), TopAbs_WIRE); exp3.More(); exp3.Next()) if (wmap.FindIndex(wire) < 1)
{ {
TopoDS_Wire wire = TopoDS::Wire (exp3.Current());
if (wmap.FindIndex(wire) < 1)
{
wmap.Add (wire); wmap.Add (wire);
for (auto edge : MyExplorer(wire, TopAbs_EDGE))
for (exp4.Init(exp3.Current(), TopAbs_EDGE); exp4.More(); exp4.Next()) if (emap.FindIndex(edge) < 1)
{ {
TopoDS_Edge edge = TopoDS::Edge(exp4.Current());
if (emap.FindIndex(edge) < 1)
{
emap.Add (edge); emap.Add (edge);
for (exp5.Init(exp4.Current(), TopAbs_VERTEX); exp5.More(); exp5.Next()) for (auto vertex : MyExplorer(edge, TopAbs_VERTEX))
{ if (vmap.FindIndex(vertex) < 1)
TopoDS_Vertex vertex = TopoDS::Vertex(exp5.Current()); vmap.Add (vertex);
if (vmap.FindIndex(vertex) < 1) }
vmap.Add (vertex); }
} }
}
}
}
}
}
}
// Free Wires // Free Wires

View File

@ -244,6 +244,32 @@ namespace netgen
string name; string name;
}; };
class MyExplorer
{
class Iterator
{
TopExp_Explorer exp;
public:
Iterator (TopoDS_Shape ashape, TopAbs_ShapeEnum atoFind, TopAbs_ShapeEnum atoAvoid)
: exp(ashape, atoFind, atoAvoid) { }
auto operator*() { return exp.Current(); }
Iterator & operator++() { exp.Next(); return *this; }
bool operator!= (nullptr_t nu) { return exp.More(); }
};
public:
TopoDS_Shape shape;
TopAbs_ShapeEnum toFind;
TopAbs_ShapeEnum toAvoid;
MyExplorer (TopoDS_Shape ashape, TopAbs_ShapeEnum atoFind, TopAbs_ShapeEnum atoAvoid = TopAbs_SHAPE)
: shape(ashape), toFind(atoFind), toAvoid(atoAvoid) { ; }
Iterator begin() { return Iterator(shape, toFind, toAvoid); }
auto end() { return nullptr; }
};
class DLL_HEADER OCCGeometry : public NetgenGeometry class DLL_HEADER OCCGeometry : public NetgenGeometry
{ {
Point<3> center; Point<3> center;