Salome HOME
Mantis issue 0021453: EDF GEOM: (regression). A fix by PKV.
[modules/geom.git] / src / NMTDS / NMTDS_Iterator.hxx
1 // Copyright (C) 2007-2011  CEA/DEN, EDF R&D, OPEN CASCADE\r
2 //\r
3 // Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,\r
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS\r
5 //\r
6 // This library is free software; you can redistribute it and/or\r
7 // modify it under the terms of the GNU Lesser General Public\r
8 // License as published by the Free Software Foundation; either\r
9 // version 2.1 of the License.\r
10 //\r
11 // This library is distributed in the hope that it will be useful,\r
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\r
14 // Lesser General Public License for more details.\r
15 //\r
16 // You should have received a copy of the GNU Lesser General Public\r
17 // License along with this library; if not, write to the Free Software\r
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA\r
19 //\r
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com\r
21 \r
22 #ifndef _NMTDS_Iterator_HeaderFile\r
23 #define _NMTDS_Iterator_HeaderFile\r
24 \r
25 #ifndef _Standard_HeaderFile\r
26 #include <Standard.hxx>\r
27 #endif\r
28 #ifndef _Standard_Macro_HeaderFile\r
29 #include <Standard_Macro.hxx>\r
30 #endif\r
31 \r
32 #ifndef _NMTDS_PShapesDataStructure_HeaderFile\r
33 #include <NMTDS_PShapesDataStructure.hxx>\r
34 #endif\r
35 #ifndef _NMTDS_ListOfPairBoolean_HeaderFile\r
36 #include <NMTDS_ListOfPairBoolean.hxx>\r
37 #endif\r
38 #ifndef _NMTDS_ListIteratorOfListOfPairBoolean_HeaderFile\r
39 #include <NMTDS_ListIteratorOfListOfPairBoolean.hxx>\r
40 #endif\r
41 #ifndef _Standard_Integer_HeaderFile\r
42 #include <Standard_Integer.hxx>\r
43 #endif\r
44 #ifndef _TColStd_DataMapOfIntegerListOfInteger_HeaderFile\r
45 #include <TColStd_DataMapOfIntegerListOfInteger.hxx>\r
46 #endif\r
47 #ifndef _TopAbs_ShapeEnum_HeaderFile\r
48 #include <TopAbs_ShapeEnum.hxx>\r
49 #endif\r
50 #ifndef _Standard_Boolean_HeaderFile\r
51 #include <Standard_Boolean.hxx>\r
52 #endif\r
53 class NMTDS_ShapesDataStructure;\r
54 class TColStd_DataMapOfIntegerListOfInteger;\r
55 \r
56 \r
57 \r
58 class NMTDS_Iterator  {\r
59 public:\r
60 \r
61   void* operator new(size_t,void* anAddress) \r
62   {\r
63     return anAddress;\r
64   }\r
65   void* operator new(size_t size) \r
66   {\r
67     return Standard::Allocate(size); \r
68   }\r
69   void  operator delete(void *anAddress) \r
70   {\r
71     if (anAddress) Standard::Free((Standard_Address&)anAddress); \r
72   }\r
73 \r
74   \r
75   Standard_EXPORT   NMTDS_Iterator();\r
76 Standard_EXPORT virtual ~NMTDS_Iterator();\r
77   \r
78   Standard_EXPORT     void SetDS(const NMTDS_PShapesDataStructure& pDS) ;\r
79   \r
80   Standard_EXPORT    const NMTDS_ShapesDataStructure& DS() const;\r
81   \r
82   Standard_EXPORT     void Initialize(const TopAbs_ShapeEnum aType1,const TopAbs_ShapeEnum aType2) ;\r
83   \r
84   Standard_EXPORT     Standard_Boolean More() const;\r
85   \r
86   Standard_EXPORT     void Next() ;\r
87   \r
88   Standard_EXPORT     void Current(Standard_Integer& aIndex1,Standard_Integer& aIndex2,Standard_Boolean& aWithSubShape) const;\r
89   \r
90   Standard_EXPORT   virtual  void Prepare() ;\r
91   \r
92   Standard_EXPORT     Standard_Integer ExpectedLength() const;\r
93   \r
94   Standard_EXPORT     Standard_Integer BlockLength() const;\r
95   \r
96   Standard_EXPORT    const TColStd_DataMapOfIntegerListOfInteger& SDVertices() const;\r
97   \r
98   Standard_EXPORT   static  void FillMVSD(const TColStd_DataMapOfIntegerListOfInteger& aMVSD1,TColStd_DataMapOfIntegerListOfInteger& aMVSD2) ;\r
99 \r
100 \r
101 protected:\r
102 \r
103   \r
104   Standard_EXPORT   virtual  void Intersect() ;\r
105 \r
106 \r
107 NMTDS_PShapesDataStructure myDS;\r
108 NMTDS_ListOfPairBoolean myLists[6];\r
109 NMTDS_ListIteratorOfListOfPairBoolean myIterator;\r
110 NMTDS_ListOfPairBoolean myEmptyList;\r
111 Standard_Integer myLength;\r
112 TColStd_DataMapOfIntegerListOfInteger myMVSD;\r
113 \r
114 \r
115 private:\r
116 \r
117 };\r
118 \r
119 // other Inline functions and methods (like "C++: function call" methods)\r
120 \r
121 \r
122 #endif\r