0027772: Foundation Classes - define Standard_Boolean using C++ type "bool" instead...
[occt.git] / src / HLRBRep / HLRBRep_EdgeData.hxx
1 // Created on: 1997-04-17
2 // Created by: Christophe MARION
3 // Copyright (c) 1997-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #ifndef _HLRBRep_EdgeData_HeaderFile
18 #define _HLRBRep_EdgeData_HeaderFile
19
20 #include <Standard.hxx>
21 #include <Standard_DefineAlloc.hxx>
22 #include <Standard_Handle.hxx>
23
24 #include <Standard_Boolean.hxx>
25 #include <Standard_Integer.hxx>
26 #include <HLRAlgo_EdgeStatus.hxx>
27 #include <HLRBRep_Curve.hxx>
28 #include <Standard_ShortReal.hxx>
29 #include <Standard_Real.hxx>
30 #include <Standard_Address.hxx>
31 class TopoDS_Edge;
32 class HLRAlgo_EdgeStatus;
33 class HLRBRep_Curve;
34
35
36
37 class HLRBRep_EdgeData 
38 {
39 public:
40
41   DEFINE_STANDARD_ALLOC
42
43   
44   Standard_EXPORT HLRBRep_EdgeData();
45   
46   Standard_EXPORT void Set (const Standard_Boolean Reg1, const Standard_Boolean RegN, const TopoDS_Edge& EG, const Standard_Integer V1, const Standard_Integer V2, const Standard_Boolean Out1, const Standard_Boolean Out2, const Standard_Boolean Cut1, const Standard_Boolean Cut2, const Standard_Real Start, const Standard_ShortReal TolStart, const Standard_Real End, const Standard_ShortReal TolEnd);
47   
48     Standard_Boolean Selected() const;
49   
50     void Selected (const Standard_Boolean B);
51   
52     Standard_Boolean Rg1Line() const;
53   
54     void Rg1Line (const Standard_Boolean B);
55   
56     Standard_Boolean RgNLine() const;
57   
58     void RgNLine (const Standard_Boolean B);
59   
60     Standard_Boolean Vertical() const;
61   
62     void Vertical (const Standard_Boolean B);
63   
64     Standard_Boolean Simple() const;
65   
66     void Simple (const Standard_Boolean B);
67   
68     Standard_Boolean OutLVSta() const;
69   
70     void OutLVSta (const Standard_Boolean B);
71   
72     Standard_Boolean OutLVEnd() const;
73   
74     void OutLVEnd (const Standard_Boolean B);
75   
76     Standard_Boolean CutAtSta() const;
77   
78     void CutAtSta (const Standard_Boolean B);
79   
80     Standard_Boolean CutAtEnd() const;
81   
82     void CutAtEnd (const Standard_Boolean B);
83   
84     Standard_Boolean VerAtSta() const;
85   
86     void VerAtSta (const Standard_Boolean B);
87   
88     Standard_Boolean VerAtEnd() const;
89   
90     void VerAtEnd (const Standard_Boolean B);
91   
92     Standard_Boolean AutoIntersectionDone() const;
93   
94     void AutoIntersectionDone (const Standard_Boolean B);
95   
96     Standard_Boolean Used() const;
97   
98     void Used (const Standard_Boolean B);
99   
100     Standard_Integer HideCount() const;
101   
102     void HideCount (const Standard_Integer I);
103   
104     Standard_Integer VSta() const;
105   
106     void VSta (const Standard_Integer I);
107   
108     Standard_Integer VEnd() const;
109   
110     void VEnd (const Standard_Integer I);
111   
112   Standard_EXPORT void UpdateMinMax (const Standard_Address TotMinMax);
113   
114     Standard_Address MinMax() const;
115   
116     HLRAlgo_EdgeStatus& Status();
117   
118     HLRBRep_Curve& ChangeGeometry();
119   
120     const HLRBRep_Curve& Geometry() const;
121   
122     Standard_Address Curve();
123   
124     Standard_ShortReal Tolerance() const;
125
126 protected:
127
128   enum EMaskFlags
129   {
130     EMaskSelected = 1,
131     EMaskUsed     = 2,
132     EMaskRg1Line  = 4,
133     EMaskVertical = 8,
134     EMaskSimple   = 16,
135     EMaskOutLVSta = 32,
136     EMaskOutLVEnd = 64,
137     EMaskIntDone  = 128,
138     EMaskCutAtSta = 256,
139     EMaskCutAtEnd = 512,
140     EMaskVerAtSta = 1024,
141     EMaskVerAtEnd = 2048,
142     EMaskRgNLine  = 4096
143   };
144
145 private:
146
147   Standard_Integer myFlags;
148   Standard_Integer myHideCount;
149   Standard_Integer myVSta;
150   Standard_Integer myVEnd;
151   Standard_Integer myMinMax[16];
152   HLRAlgo_EdgeStatus myStatus;
153   HLRBRep_Curve myGeometry;
154   Standard_ShortReal myTolerance;
155
156 };
157
158 #include <HLRBRep_EdgeData.lxx>
159
160 #endif // _HLRBRep_EdgeData_HeaderFile