Salome HOME
IsDimSupported method added
[modules/smesh.git] / src / SMDS / SMDS_IteratorOfElements.hxx
1 //  SMESH SMDS : implementaion of Salome mesh data structure
2 //
3 //  Copyright (C) 2003  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. 
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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org 
21
22 #include "SMDS_Iterator.hxx"
23 #include "SMDS_MeshElement.hxx"
24 #include <set>
25
26
27 class SMDS_IteratorOfElements:public SMDS_ElemIterator
28 {
29   public:
30 /////////////////////////////////////////////////////////////////////////////
31 /// Create an iterator which look for elements of type type which are linked 
32 /// to the element element. it is the iterator to get connectivity of element
33 //////////////////////////////////////////////////////////////////////////////
34         SMDS_IteratorOfElements(const SMDS_MeshElement * element,
35                                 SMDSAbs_ElementType type,
36                                 const SMDS_ElemIteratorPtr& it);
37         bool more();
38         const SMDS_MeshElement * next();
39
40   private:
41         SMDS_ElemIteratorPtr t2Iterator;
42         SMDS_ElemIteratorPtr t1Iterator;
43         SMDSAbs_ElementType myType;     
44         const SMDS_MeshElement * myProxyElement;
45         const SMDS_MeshElement * myElement;             
46         bool myReverseIteration;
47
48         std::set<const SMDS_MeshElement*> alreadyReturnedElements;
49         std::set<const SMDS_MeshElement*>::iterator itAlreadyReturned;  
50         bool subMore();
51         const SMDS_MeshElement * subNext();
52 };