Salome HOME
Join modifications from branch BR_DEBUG_3_2_0b1
[modules/geom.git] / src / NMTTools / NMTTools_IndexedDataMapOfShapeIndexedMapOfShape.hxx
1 // Copyright (C) 2005  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
2 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
3 // 
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either 
7 // version 2.1 of the License.
8 // 
9 // This library is distributed in the hope that it will be useful 
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU 
12 // Lesser General Public License for more details.
13 //
14 // You should have received a copy of the GNU Lesser General Public  
15 // License along with this library; if not, write to the Free Software 
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 //
18 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19
20 #ifndef _NMTTools_IndexedDataMapOfShapeIndexedMapOfShape_HeaderFile
21 #define _NMTTools_IndexedDataMapOfShapeIndexedMapOfShape_HeaderFile
22
23 #ifndef _TCollection_BasicMap_HeaderFile
24 #include <TCollection_BasicMap.hxx>
25 #endif
26 #ifndef _Handle_NMTTools_IndexedDataMapNodeOfIndexedDataMapOfShapeIndexedMapOfShape_HeaderFile
27 #include <Handle_NMTTools_IndexedDataMapNodeOfIndexedDataMapOfShapeIndexedMapOfShape.hxx>
28 #endif
29 #ifndef _Standard_Integer_HeaderFile
30 #include <Standard_Integer.hxx>
31 #endif
32 #ifndef _Standard_Boolean_HeaderFile
33 #include <Standard_Boolean.hxx>
34 #endif
35 class Standard_DomainError;
36 class Standard_OutOfRange;
37 class Standard_NoSuchObject;
38 class TopoDS_Shape;
39 class TopTools_IndexedMapOfShape;
40 class TopTools_ShapeMapHasher;
41 class NMTTools_IndexedDataMapNodeOfIndexedDataMapOfShapeIndexedMapOfShape;
42
43
44 #ifndef _Standard_HeaderFile
45 #include <Standard.hxx>
46 #endif
47 #ifndef _Standard_Macro_HeaderFile
48 #include <Standard_Macro.hxx>
49 #endif
50
51 class NMTTools_IndexedDataMapOfShapeIndexedMapOfShape  : public TCollection_BasicMap {
52
53 public:
54
55     void* operator new(size_t,void* anAddress) 
56       {
57         return anAddress;
58       }
59     void* operator new(size_t size) 
60       { 
61         return Standard::Allocate(size); 
62       }
63     void  operator delete(void *anAddress) 
64       { 
65         if (anAddress) Standard::Free((Standard_Address&)anAddress); 
66       }
67  // Methods PUBLIC
68  // 
69 Standard_EXPORT NMTTools_IndexedDataMapOfShapeIndexedMapOfShape(const Standard_Integer NbBuckets = 1);
70 Standard_EXPORT   NMTTools_IndexedDataMapOfShapeIndexedMapOfShape& Assign(const NMTTools_IndexedDataMapOfShapeIndexedMapOfShape& Other) ;
71   NMTTools_IndexedDataMapOfShapeIndexedMapOfShape& operator =(const NMTTools_IndexedDataMapOfShapeIndexedMapOfShape& Other) 
72 {
73   return Assign(Other);
74 }
75
76 Standard_EXPORT   void ReSize(const Standard_Integer NbBuckets) ;
77 Standard_EXPORT   void Clear() ;
78 ~NMTTools_IndexedDataMapOfShapeIndexedMapOfShape()
79 {
80   Clear();
81 }
82
83 Standard_EXPORT   Standard_Integer Add(const TopoDS_Shape& K,const TopTools_IndexedMapOfShape& I) ;
84 Standard_EXPORT   void Substitute(const Standard_Integer I,const TopoDS_Shape& K,const TopTools_IndexedMapOfShape& T) ;
85 Standard_EXPORT   void RemoveLast() ;
86 Standard_EXPORT   Standard_Boolean Contains(const TopoDS_Shape& K) const;
87 Standard_EXPORT  const TopoDS_Shape& FindKey(const Standard_Integer I) const;
88 Standard_EXPORT  const TopTools_IndexedMapOfShape& FindFromIndex(const Standard_Integer I) const;
89  const TopTools_IndexedMapOfShape& operator ()(const Standard_Integer I) const
90 {
91   return FindFromIndex(I);
92 }
93
94 Standard_EXPORT   TopTools_IndexedMapOfShape& ChangeFromIndex(const Standard_Integer I) ;
95   TopTools_IndexedMapOfShape& operator ()(const Standard_Integer I) 
96 {
97   return ChangeFromIndex(I);
98 }
99
100 Standard_EXPORT   Standard_Integer FindIndex(const TopoDS_Shape& K) const;
101 Standard_EXPORT  const TopTools_IndexedMapOfShape& FindFromKey(const TopoDS_Shape& K) const;
102 Standard_EXPORT   TopTools_IndexedMapOfShape& ChangeFromKey(const TopoDS_Shape& K) ;
103
104
105
106
107
108 protected:
109
110  // Methods PROTECTED
111  // 
112
113
114  // Fields PROTECTED
115  //
116
117
118 private: 
119
120  // Methods PRIVATE
121  // 
122 Standard_EXPORT NMTTools_IndexedDataMapOfShapeIndexedMapOfShape(const NMTTools_IndexedDataMapOfShapeIndexedMapOfShape& Other);
123
124
125  // Fields PRIVATE
126  //
127
128
129 };
130
131
132
133
134
135 // other Inline functions and methods (like "C++: function call" methods)
136 //
137
138
139 #endif