Salome HOME
IMP 0021129: EDF 1541 GEOM: Problem with GetInPlace. A new GetInPlace implementation...
[modules/geom.git] / src / GEOMAlgo / GEOMAlgo_DataMapOfShapePnt.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 _GEOMAlgo_DataMapOfShapePnt_HeaderFile\r
23 #define _GEOMAlgo_DataMapOfShapePnt_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 _TCollection_BasicMap_HeaderFile\r
33 #include <TCollection_BasicMap.hxx>\r
34 #endif\r
35 #ifndef _Handle_GEOMAlgo_DataMapNodeOfDataMapOfShapePnt_HeaderFile\r
36 #include <Handle_GEOMAlgo_DataMapNodeOfDataMapOfShapePnt.hxx>\r
37 #endif\r
38 #ifndef _Standard_Integer_HeaderFile\r
39 #include <Standard_Integer.hxx>\r
40 #endif\r
41 #ifndef _Standard_Boolean_HeaderFile\r
42 #include <Standard_Boolean.hxx>\r
43 #endif\r
44 class Standard_DomainError;\r
45 class Standard_NoSuchObject;\r
46 class TopoDS_Shape;\r
47 class gp_Pnt;\r
48 class TopTools_ShapeMapHasher;\r
49 class GEOMAlgo_DataMapNodeOfDataMapOfShapePnt;\r
50 class GEOMAlgo_DataMapIteratorOfDataMapOfShapePnt;\r
51 \r
52 \r
53 \r
54 class GEOMAlgo_DataMapOfShapePnt  : public TCollection_BasicMap {\r
55 public:\r
56 \r
57   void* operator new(size_t,void* anAddress) \r
58   {\r
59     return anAddress;\r
60   }\r
61   void* operator new(size_t size) \r
62   {\r
63     return Standard::Allocate(size); \r
64   }\r
65   void  operator delete(void *anAddress) \r
66   {\r
67     if (anAddress) Standard::Free((Standard_Address&)anAddress); \r
68   }\r
69 \r
70   \r
71   Standard_EXPORT   GEOMAlgo_DataMapOfShapePnt(const Standard_Integer NbBuckets = 1);\r
72   \r
73   Standard_EXPORT     GEOMAlgo_DataMapOfShapePnt& Assign(const GEOMAlgo_DataMapOfShapePnt& Other) ;\r
74     GEOMAlgo_DataMapOfShapePnt& operator =(const GEOMAlgo_DataMapOfShapePnt& Other) \r
75 {\r
76   return Assign(Other);\r
77 }\r
78   \r
79   Standard_EXPORT     void ReSize(const Standard_Integer NbBuckets) ;\r
80   \r
81   Standard_EXPORT     void Clear() ;\r
82 ~GEOMAlgo_DataMapOfShapePnt()\r
83 {\r
84   Clear();\r
85 }\r
86   \r
87   Standard_EXPORT     Standard_Boolean Bind(const TopoDS_Shape& K,const gp_Pnt& I) ;\r
88   \r
89   Standard_EXPORT     Standard_Boolean IsBound(const TopoDS_Shape& K) const;\r
90   \r
91   Standard_EXPORT     Standard_Boolean UnBind(const TopoDS_Shape& K) ;\r
92   \r
93   Standard_EXPORT    const gp_Pnt& Find(const TopoDS_Shape& K) const;\r
94    const gp_Pnt& operator()(const TopoDS_Shape& K) const\r
95 {\r
96   return Find(K);\r
97 }\r
98   \r
99   Standard_EXPORT     gp_Pnt& ChangeFind(const TopoDS_Shape& K) ;\r
100     gp_Pnt& operator()(const TopoDS_Shape& K) \r
101 {\r
102   return ChangeFind(K);\r
103 }\r
104 \r
105 \r
106 \r
107 \r
108 \r
109 protected:\r
110 \r
111 \r
112 \r
113 \r
114 \r
115 private:\r
116 \r
117   \r
118   Standard_EXPORT   GEOMAlgo_DataMapOfShapePnt(const GEOMAlgo_DataMapOfShapePnt& Other);\r
119 \r
120 \r
121 \r
122 \r
123 };\r
124 \r
125 \r
126 \r
127 \r
128 \r
129 // other Inline functions and methods (like "C++: function call" methods)\r
130 \r
131 \r
132 #endif\r