0024428: Implementation of LGPL license
[occt.git] / src / StepElement / StepElement_CurveElementFreedom.cxx
1 // Created on: 2002-12-10
2 // Created by: data exchange team
3 // Copyright (c) 2002-2014 OPEN CASCADE SAS
4 //
5 // This file is part of Open CASCADE Technology software library.
6 //
7 // This library is free software; you can redistribute it and / or modify it
8 // under the terms of the GNU Lesser General Public version 2.1 as published
9 // by the Free Software Foundation, with special exception defined in the file
10 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
11 // distribution for complete text of the license and disclaimer of any warranty.
12 //
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
15
16 // Generator:   ExpToCas (EXPRESS -> CASCADE/XSTEP Translator) V2.0
17
18 #include <StepElement_CurveElementFreedom.ixx>
19 #include <StepElement_CurveElementFreedomMember.hxx>
20 #include <TCollection_HAsciiString.hxx>
21
22 static Standard_CString anEnum = "ENUMERATED_CURVE_ELEMENT_FREEDOM";
23 static Standard_CString anApp = "APPLICATION_DEFINED_DEGREE_OF_FREEDOM";
24 //=======================================================================
25 //function : StepElement_CurveElementFreedom
26 //purpose  : 
27 //=======================================================================
28
29 StepElement_CurveElementFreedom::StepElement_CurveElementFreedom ()
30 {
31 }
32
33 //=======================================================================
34 //function : CaseNum
35 //purpose  : 
36 //=======================================================================
37
38 Standard_Integer StepElement_CurveElementFreedom::CaseNum (const Handle(Standard_Transient)& /*ent*/) const
39 {
40   return 0;
41 }
42
43 //=======================================================================
44 //function : CaseMem
45 //purpose  : 
46 //=======================================================================
47
48 Standard_Integer StepElement_CurveElementFreedom::CaseMem (const Handle(StepData_SelectMember)& ent) const
49 {
50  if(ent.IsNull()) return 0;
51  if(ent->Matches(anEnum)) return 1;
52  else if(ent->Matches(anApp)) return 2;
53  else return 0;
54 }
55
56 //=======================================================================
57 //function : NewMember
58 //purpose  : 
59 //=======================================================================
60
61 Handle(StepData_SelectMember) StepElement_CurveElementFreedom::NewMember() const
62 {
63  return new StepElement_CurveElementFreedomMember;
64 }
65
66 //=======================================================================
67 //function : SetEnumeratedCurveElementFreedom
68 //purpose  : 
69 //=======================================================================
70
71 void StepElement_CurveElementFreedom::SetEnumeratedCurveElementFreedom (const StepElement_EnumeratedCurveElementFreedom val)
72 {
73   Handle(StepElement_CurveElementFreedomMember) SelMem = Handle(StepElement_CurveElementFreedomMember)::DownCast(Value());
74   if(SelMem.IsNull()) return;
75  Handle(TCollection_HAsciiString) name = new TCollection_HAsciiString("ENUMERATED_CURVE_ELEMENT_FREEDOM");
76  SelMem->SetName(name->ToCString());
77  SelMem->SetEnum((Standard_Integer)val);
78 }
79
80 //=======================================================================
81 //function : EnumeratedCurveElementFreedom
82 //purpose  : 
83 //=======================================================================
84
85 StepElement_EnumeratedCurveElementFreedom StepElement_CurveElementFreedom::EnumeratedCurveElementFreedom () const
86 {
87   Handle(StepElement_CurveElementFreedomMember) SelMem = Handle(StepElement_CurveElementFreedomMember)::DownCast(Value());
88   if(SelMem.IsNull()) return StepElement_None;
89   Handle(TCollection_HAsciiString) name = new TCollection_HAsciiString;
90   name->AssignCat(SelMem->Name());
91   Handle(TCollection_HAsciiString) nameitem = new TCollection_HAsciiString("ENUMERATED_CURVE_ELEMENT_FREEDOM");
92   if(name->IsDifferent(nameitem)) return StepElement_None;
93   Standard_Integer numit = SelMem->Enum();
94   StepElement_EnumeratedCurveElementFreedom val;
95   switch(numit) {
96   case 1 : val = StepElement_XTranslation; break;
97   case 2 : val = StepElement_YTranslation; break;
98   case 3 : val = StepElement_ZTranslation; break;
99   case 4 : val = StepElement_XRotation; break;
100   case 5 : val = StepElement_YRotation; break;
101   case 6 : val = StepElement_ZRotation; break;
102   case 7 : val = StepElement_Warp; break;
103   case 8 : val = StepElement_None; break;
104     default : return StepElement_None;break;
105   }
106  return val;
107 }
108
109 //=======================================================================
110 //function : SetApplicationDefinedDegreeOfFreedom
111 //purpose  : 
112 //=======================================================================
113
114 void StepElement_CurveElementFreedom::SetApplicationDefinedDegreeOfFreedom (const Handle(TCollection_HAsciiString) &val)
115 {
116   Handle(StepElement_CurveElementFreedomMember) SelMem = Handle(StepElement_CurveElementFreedomMember)::DownCast(Value());
117   if(SelMem.IsNull()) return;
118  Handle(TCollection_HAsciiString) name = new TCollection_HAsciiString("APPLICATION_DEFINED_DEGREE_OF_FREEDOM");
119  SelMem->SetName(name->ToCString());
120  SelMem->SetString(val->ToCString());
121 }
122
123 //=======================================================================
124 //function : ApplicationDefinedDegreeOfFreedom
125 //purpose  : 
126 //=======================================================================
127
128 Handle(TCollection_HAsciiString) StepElement_CurveElementFreedom::ApplicationDefinedDegreeOfFreedom () const
129 {
130   Handle(StepElement_CurveElementFreedomMember) SelMem = Handle(StepElement_CurveElementFreedomMember)::DownCast(Value());
131   if(SelMem.IsNull()) return 0;
132  Handle(TCollection_HAsciiString) name = new TCollection_HAsciiString;
133  name->AssignCat(SelMem->Name());
134  Handle(TCollection_HAsciiString) nameitem = new TCollection_HAsciiString("APPLICATION_DEFINED_DEGREE_OF_FREEDOM");
135  if(name->IsDifferent(nameitem)) return 0;
136  Handle(TCollection_HAsciiString) val = new TCollection_HAsciiString;
137  val->AssignCat(SelMem->String());
138  return val;
139 }