Version: 9.12.0
SMDS_MeshGroup.hxx
Go to the documentation of this file.
1 // Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
10 //
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
15 //
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 
23 // SMESH SMDS : implementation of Salome mesh data structure
24 // File : SMDS_MeshGroup.hxx
25 // Module : SMESH
26 //
27 #ifndef _SMDS_MeshGroup_HeaderFile
28 #define _SMDS_MeshGroup_HeaderFile
29 
30 #include "SMESH_SMDS.hxx"
31 
32 #include "SMDS_ElementHolder.hxx"
33 #include "SMDS_Mesh.hxx"
34 #include <set>
35 
37 {
38  public:
39  SMDS_MeshGroup(const SMDS_Mesh * theMesh,
40  const SMDSAbs_ElementType theType = SMDSAbs_All);
41 
42  void SetType (const SMDSAbs_ElementType theType);
43  void Clear();
44  void Reserve(size_t /*nbElems*/) {}
45  bool Add(const SMDS_MeshElement * theElem);
46  bool Remove(const SMDS_MeshElement * theElem);
47  bool IsEmpty() const { return myElements.empty(); }
48  smIdType Extent() const { return (smIdType) myElements.size(); }
49  int Tic() const { return myTic; }
50  bool Contains(const SMDS_MeshElement * theElem) const;
51 
52  const SMDS_Mesh* GetMesh() const { return myMesh; }
53  SMDSAbs_ElementType GetType() const { return myType; }
54  SMDS_ElemIteratorPtr GetElements() const; // WARNING: iterator becomes invalid if group changes
55 
56  void operator=( SMDS_MeshGroup && other );
57 
58  protected: // methods of SMDS_ElementHolder
59 
60  virtual SMDS_ElemIteratorPtr getElements() { return GetElements(); }
61  virtual void tmpClear();
62  virtual void add( const SMDS_MeshElement* element ) { Add( element ); }
63  virtual void compact() {}
64 
65  private:
66 
67  typedef std::set< const SMDS_MeshElement* > TElementSet;
68  typedef TElementSet::const_iterator TIterator;
69 
70  const SMDS_Mesh * myMesh;
72  TElementSet myElements; // not sorted by ID because it can contain deleted elements
73  int myTic; // to track changes
74 };
75 #endif
SMDSAbs_ElementType
Type (node, edge, face or volume) of elements.
Definition: SMDSAbs_ElementType.hxx:34
@ SMDSAbs_All
Definition: SMDSAbs_ElementType.hxx:35
boost::shared_ptr< SMDS_Iterator< const SMDS_MeshElement * > > SMDS_ElemIteratorPtr
Definition: SMDS_ElemIterator.hxx:43
#define SMDS_EXPORT
Definition: SMESH_SMDS.hxx:37
Base class of object holding SMDS_MeshElement pointers.
Definition: SMDS_ElementHolder.hxx:48
virtual void tmpClear()=0
the descendant object re-add its elements after the mesh compacting
SMDS_Mesh * myMesh
Definition: SMDS_ElementHolder.hxx:75
Base class for elements.
Definition: SMDS_MeshElement.hxx:56
Definition: SMDS_MeshGroup.hxx:37
virtual void add(const SMDS_MeshElement *element)
the descendant squeeze its element storage after re-adding elements
Definition: SMDS_MeshGroup.hxx:62
smIdType Extent() const
Definition: SMDS_MeshGroup.hxx:48
void Reserve(size_t)
Definition: SMDS_MeshGroup.hxx:44
int Tic() const
Definition: SMDS_MeshGroup.hxx:49
const SMDS_Mesh * myMesh
Definition: SMDS_MeshGroup.hxx:70
virtual SMDS_ElemIteratorPtr getElements()
< the descendant object return its elements just before the mesh compacting
Definition: SMDS_MeshGroup.hxx:60
const SMDS_Mesh * GetMesh() const
Definition: SMDS_MeshGroup.hxx:52
int myTic
Definition: SMDS_MeshGroup.hxx:73
SMDSAbs_ElementType GetType() const
Definition: SMDS_MeshGroup.hxx:53
SMDSAbs_ElementType myType
Definition: SMDS_MeshGroup.hxx:71
virtual void compact()
allow the descendant treat its elements before mesh clearing
Definition: SMDS_MeshGroup.hxx:63
TElementSet myElements
Definition: SMDS_MeshGroup.hxx:72
TElementSet::const_iterator TIterator
Definition: SMDS_MeshGroup.hxx:68
bool IsEmpty() const
Definition: SMDS_MeshGroup.hxx:47
std::set< const SMDS_MeshElement * > TElementSet
Definition: SMDS_MeshGroup.hxx:67
Definition: SMDS_MeshObject.hxx:33
Definition: SMDS_Mesh.hxx:53
ENUM Add(ENUM v, int delta)
Return incremented enum value.
Definition: SMESH_TypeDefs.hxx:137