Salome HOME
Merge with OCC-V2_1_0_deb
[modules/geom.git] / src / GEOMAlgo / GEOMAlgo_PassKey.hxx
1 // File generated by CPPExt (Value)
2 //
3 //                     Copyright (C) 1991 - 2000 by  
4 //                      Matra Datavision SA.  All rights reserved.
5 //  
6 //                     Copyright (C) 2001 - 2004 by
7 //                     Open CASCADE SA.  All rights reserved.
8 // 
9 // This file is part of the Open CASCADE Technology software.
10 //
11 // This software may be distributed and/or modified under the terms and
12 // conditions of the Open CASCADE Public License as defined by Open CASCADE SA
13 // and appearing in the file LICENSE included in the packaging of this file.
14 //  
15 // This software is distributed on an "AS IS" basis, without warranty of any
16 // kind, and Open CASCADE SA hereby disclaims all such warranties,
17 // including without limitation, any warranties of merchantability, fitness
18 // for a particular purpose or non-infringement. Please see the License for
19 // the specific terms and conditions governing rights and limitations under the
20 // License.
21
22 #ifndef _GEOMAlgo_PassKey_HeaderFile
23 #define _GEOMAlgo_PassKey_HeaderFile
24
25 #ifndef _Standard_Integer_HeaderFile
26 #include <Standard_Integer.hxx>
27 #endif
28 #ifndef _TopoDS_Shape_HeaderFile
29 #include <TopoDS_Shape.hxx>
30 #endif
31 #ifndef _Standard_Boolean_HeaderFile
32 #include <Standard_Boolean.hxx>
33 #endif
34 #ifndef _Standard_Address_HeaderFile
35 #include <Standard_Address.hxx>
36 #endif
37 class TopoDS_Shape;
38 class TopTools_ListOfShape;
39
40
41 #ifndef _Standard_HeaderFile
42 #include <Standard.hxx>
43 #endif
44 #ifndef _Standard_Macro_HeaderFile
45 #include <Standard_Macro.hxx>
46 #endif
47
48 class GEOMAlgo_PassKey  {
49
50 public:
51
52     void* operator new(size_t,void* anAddress) 
53       {
54         return anAddress;
55       }
56     void* operator new(size_t size) 
57       { 
58         return Standard::Allocate(size); 
59       }
60     void  operator delete(void *anAddress) 
61       { 
62         if (anAddress) Standard::Free((Standard_Address&)anAddress); 
63       }
64  // Methods PUBLIC
65  // 
66 Standard_EXPORT GEOMAlgo_PassKey();
67 Standard_EXPORT   GEOMAlgo_PassKey& Assign(const GEOMAlgo_PassKey& Other) ;
68   GEOMAlgo_PassKey& operator =(const GEOMAlgo_PassKey& Other) 
69 {
70   return Assign(Other);
71 }
72
73 Standard_EXPORT   void SetIds(const TopoDS_Shape& aS) ;
74 Standard_EXPORT   void SetIds(const TopoDS_Shape& aS1,const TopoDS_Shape& aS2) ;
75 Standard_EXPORT   void SetIds(const TopoDS_Shape& aS1,const TopoDS_Shape& aS2,const TopoDS_Shape& aS3) ;
76 Standard_EXPORT   void SetIds(const TopoDS_Shape& aS1,const TopoDS_Shape& aS2,const TopoDS_Shape& aS3,const TopoDS_Shape& aS4) ;
77 Standard_EXPORT   void SetIds(const TopTools_ListOfShape& aLS) ;
78 Standard_EXPORT   Standard_Integer NbMax() const;
79 Standard_EXPORT   void Clear() ;
80 Standard_EXPORT   void Compute() ;
81 Standard_EXPORT   Standard_Boolean IsEqual(const GEOMAlgo_PassKey& aOther) const;
82 Standard_EXPORT   Standard_Address Key() const;
83 Standard_EXPORT   Standard_Integer HashCode(const Standard_Integer Upper) const;
84 Standard_EXPORT   void Dump() const;
85
86
87
88
89
90 protected:
91
92  // Methods PROTECTED
93  // 
94
95
96  // Fields PROTECTED
97  //
98 Standard_Integer myNbIds;
99 Standard_Integer myNbMax;
100 Standard_Integer mySum;
101 Standard_Integer myIds[8];
102 TopoDS_Shape myShapes[8];
103 Standard_Integer myUpper;
104
105
106 private: 
107
108  // Methods PRIVATE
109  // 
110
111
112  // Fields PRIVATE
113  //
114
115
116 };
117
118
119
120
121
122 // other Inline functions and methods (like "C++: function call" methods)
123 //
124
125
126 #endif