782c2401a7a6eaf8ec48469992ec7c7a6c585b99
[occt.git] / src / PTopoDS / PTopoDS_TShape.cxx
1 // Created on: 1993-03-09
2 // Created by: Remi LEQUETTE
3 // Copyright (c) 1993-1999 Matra Datavision
4 // Copyright (c) 1999-2012 OPEN CASCADE SAS
5 //
6 // The content of this file is subject to the Open CASCADE Technology Public
7 // License Version 6.5 (the "License"). You may not use the content of this file
8 // except in compliance with the License. Please obtain a copy of the License
9 // at http://www.opencascade.org and read it completely before using this file.
10 //
11 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
12 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
13 //
14 // The Original Code and all software distributed under the License is
15 // distributed on an "AS IS" basis, without warranty of any kind, and the
16 // Initial Developer hereby disclaims all such warranties, including without
17 // limitation, any warranties of merchantability, fitness for a particular
18 // purpose or non-infringement. Please see the License for the specific terms
19 // and conditions governing the rights and limitations under the License.
20
21
22 #include <PTopoDS_TShape.ixx>
23
24 // static const Standard_Integer FreeMask       = 1;
25 // FreeMask has no sense in D.B. context; it is free for future use.
26 static const Standard_Integer ModifiedMask   = 2;
27 static const Standard_Integer CheckedMask    = 4;
28 static const Standard_Integer OrientableMask = 8;
29 static const Standard_Integer ClosedMask     = 16;
30 static const Standard_Integer InfiniteMask   = 32;
31 static const Standard_Integer ConvexMask     = 64;
32
33
34 //=======================================================================
35 //function : PTopoDS_TShape
36 //purpose  : 
37 //=======================================================================
38
39 PTopoDS_TShape::PTopoDS_TShape() :
40        myFlags(0)
41 {
42   // UPDATE FMA - 28-11-95
43   // These two flags are always set to the Transient Value
44   //Modified(Standard_True);
45   //Orientable(Standard_True);
46 }
47
48
49 //=======================================================================
50 //function : Modified
51 //purpose  : 
52 //=======================================================================
53
54 Standard_Boolean  PTopoDS_TShape::Modified() const 
55 {
56   return myFlags & ModifiedMask;
57 }
58
59 //=======================================================================
60 //function : Modified
61 //purpose  : 
62 //=======================================================================
63
64 void  PTopoDS_TShape::Modified(const Standard_Boolean M)
65 {
66   if (M) myFlags |= ModifiedMask;
67   else   myFlags &= ~ModifiedMask;
68 }
69
70 //=======================================================================
71 //function : Checked
72 //purpose  : 
73 //=======================================================================
74
75 Standard_Boolean  PTopoDS_TShape::Checked() const 
76 {
77   return myFlags & CheckedMask;
78 }
79
80 //=======================================================================
81 //function : Checked
82 //purpose  : 
83 //=======================================================================
84
85 void  PTopoDS_TShape::Checked(const Standard_Boolean M)
86 {
87   if (M) myFlags |= CheckedMask;
88   else   myFlags &= ~CheckedMask;
89 }
90
91 //=======================================================================
92 //function : Orientable
93 //purpose  : 
94 //=======================================================================
95
96 Standard_Boolean  PTopoDS_TShape::Orientable() const 
97 {
98   return myFlags & OrientableMask;
99 }
100
101 //=======================================================================
102 //function : Orientable
103 //purpose  : 
104 //=======================================================================
105
106 void  PTopoDS_TShape::Orientable(const Standard_Boolean M)
107 {
108   if (M) myFlags |= OrientableMask;
109   else   myFlags &= ~OrientableMask;
110 }
111
112 //=======================================================================
113 //function : Closed
114 //purpose  : 
115 //=======================================================================
116
117 Standard_Boolean  PTopoDS_TShape::Closed() const 
118 {
119   return myFlags & ClosedMask;
120 }
121
122 //=======================================================================
123 //function : Closed
124 //purpose  : 
125 //=======================================================================
126
127 void  PTopoDS_TShape::Closed(const Standard_Boolean M)
128 {
129   if (M) myFlags |= ClosedMask;
130   else   myFlags &= ~ClosedMask;
131 }
132
133 //=======================================================================
134 //function : Infinite
135 //purpose  : 
136 //=======================================================================
137
138 Standard_Boolean  PTopoDS_TShape::Infinite() const 
139 {
140   return myFlags & InfiniteMask;
141 }
142
143 //=======================================================================
144 //function : Infinite
145 //purpose  : 
146 //=======================================================================
147
148 void  PTopoDS_TShape::Infinite(const Standard_Boolean M)
149 {
150   if (M) myFlags |= InfiniteMask;
151   else   myFlags &= ~InfiniteMask;
152 }
153
154 //=======================================================================
155 //function : Convex
156 //purpose  : 
157 //=======================================================================
158
159 Standard_Boolean  PTopoDS_TShape::Convex() const 
160 {
161   return myFlags & ConvexMask;
162 }
163
164 //=======================================================================
165 //function : Convex
166 //purpose  : 
167 //=======================================================================
168
169 void  PTopoDS_TShape::Convex(const Standard_Boolean M)
170 {
171   if (M) myFlags |= ConvexMask;
172   else   myFlags &= ~ConvexMask;
173 }
174
175
176 //=======================================================================
177 //function : Shapes
178 //purpose  : returns the array of sub-shapes
179 //=======================================================================
180
181 Handle(PTopoDS_HArray1OfHShape) PTopoDS_TShape::Shapes() const
182 {
183   return myShapes;
184 }
185
186 //=======================================================================
187 //function : Shapes
188 //purpose  : returns the Ith element of the array of sub-shapes
189 //=======================================================================
190
191 Handle(PTopoDS_HShape)
192 PTopoDS_TShape::Shapes(const Standard_Integer i) const
193 {
194   return myShapes->Value(i);
195 }
196
197 //=======================================================================
198 //function : Shapes
199 //purpose  : Sets the array of sub-shapes
200 //=======================================================================
201
202 void PTopoDS_TShape::Shapes(const Handle(PTopoDS_HArray1OfHShape)& S)
203 {
204   myShapes = S;
205 }
206
207 //=======================================================================
208 //function : Shapes
209 //purpose  : Sets the Ith element of the array of sub-shapes
210 //=======================================================================
211
212 void PTopoDS_TShape::Shapes(const Standard_Integer i,
213                             const Handle(PTopoDS_HShape)& S)
214 {
215   myShapes->SetValue(i, S);
216 }
217