1 // Created on: 2002-12-10
2 // Created by: data exchange team
3 // Copyright (c) 2002-2014 OPEN CASCADE SAS
5 // This file is part of Open CASCADE Technology software library.
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.
13 // Alternatively, this file may be used under the terms of Open CASCADE
14 // commercial license or contractual agreement.
16 // Generator: ExpToCas (EXPRESS -> CASCADE/XSTEP Translator) V2.0
18 #include <StepElement_CurveElementFreedom.ixx>
19 #include <StepElement_CurveElementFreedomMember.hxx>
20 #include <TCollection_HAsciiString.hxx>
22 static Standard_CString anEnum = "ENUMERATED_CURVE_ELEMENT_FREEDOM";
23 static Standard_CString anApp = "APPLICATION_DEFINED_DEGREE_OF_FREEDOM";
24 //=======================================================================
25 //function : StepElement_CurveElementFreedom
27 //=======================================================================
29 StepElement_CurveElementFreedom::StepElement_CurveElementFreedom ()
33 //=======================================================================
36 //=======================================================================
38 Standard_Integer StepElement_CurveElementFreedom::CaseNum (const Handle(Standard_Transient)& /*ent*/) const
43 //=======================================================================
46 //=======================================================================
48 Standard_Integer StepElement_CurveElementFreedom::CaseMem (const Handle(StepData_SelectMember)& ent) const
50 if(ent.IsNull()) return 0;
51 if(ent->Matches(anEnum)) return 1;
52 else if(ent->Matches(anApp)) return 2;
56 //=======================================================================
57 //function : NewMember
59 //=======================================================================
61 Handle(StepData_SelectMember) StepElement_CurveElementFreedom::NewMember() const
63 return new StepElement_CurveElementFreedomMember;
66 //=======================================================================
67 //function : SetEnumeratedCurveElementFreedom
69 //=======================================================================
71 void StepElement_CurveElementFreedom::SetEnumeratedCurveElementFreedom (const StepElement_EnumeratedCurveElementFreedom val)
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);
80 //=======================================================================
81 //function : EnumeratedCurveElementFreedom
83 //=======================================================================
85 StepElement_EnumeratedCurveElementFreedom StepElement_CurveElementFreedom::EnumeratedCurveElementFreedom () const
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;
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;
109 //=======================================================================
110 //function : SetApplicationDefinedDegreeOfFreedom
112 //=======================================================================
114 void StepElement_CurveElementFreedom::SetApplicationDefinedDegreeOfFreedom (const Handle(TCollection_HAsciiString) &val)
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());
123 //=======================================================================
124 //function : ApplicationDefinedDegreeOfFreedom
126 //=======================================================================
128 Handle(TCollection_HAsciiString) StepElement_CurveElementFreedom::ApplicationDefinedDegreeOfFreedom () const
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());