0031687: Draw Harness, ViewerTest - extend command vrenderparams with option updating...
[occt.git] / src / RWStepShape / RWStepShape_RWRightAngularWedge.cxx
1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
2 //
3 // This file is part of Open CASCADE Technology software library.
4 //
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
10 //
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
13
14
15 #include <Interface_Check.hxx>
16 #include <Interface_EntityIterator.hxx>
17 #include <RWStepShape_RWRightAngularWedge.hxx>
18 #include <StepData_StepReaderData.hxx>
19 #include <StepData_StepWriter.hxx>
20 #include <StepGeom_Axis2Placement3d.hxx>
21 #include <StepShape_RightAngularWedge.hxx>
22
23 RWStepShape_RWRightAngularWedge::RWStepShape_RWRightAngularWedge () {}
24
25 void RWStepShape_RWRightAngularWedge::ReadStep
26         (const Handle(StepData_StepReaderData)& data,
27          const Standard_Integer num,
28          Handle(Interface_Check)& ach,
29          const Handle(StepShape_RightAngularWedge)& ent) const
30 {
31
32
33         // --- Number of Parameter Control ---
34
35         if (!data->CheckNbParams(num,6,ach,"right_angular_wedge")) return;
36
37         // --- inherited field : name ---
38
39         Handle(TCollection_HAsciiString) aName;
40         //szv#4:S4163:12Mar99 `Standard_Boolean stat1 =` not needed
41         data->ReadString (num,1,"name",ach,aName);
42
43         // --- own field : position ---
44
45         Handle(StepGeom_Axis2Placement3d) aPosition;
46         //szv#4:S4163:12Mar99 `Standard_Boolean stat2 =` not needed
47         data->ReadEntity(num, 2,"position", ach, STANDARD_TYPE(StepGeom_Axis2Placement3d), aPosition);
48
49         // --- own field : x ---
50
51         Standard_Real aX;
52         //szv#4:S4163:12Mar99 `Standard_Boolean stat3 =` not needed
53         data->ReadReal (num,3,"x",ach,aX);
54
55         // --- own field : y ---
56
57         Standard_Real aY;
58         //szv#4:S4163:12Mar99 `Standard_Boolean stat4 =` not needed
59         data->ReadReal (num,4,"y",ach,aY);
60
61         // --- own field : z ---
62
63         Standard_Real aZ;
64         //szv#4:S4163:12Mar99 `Standard_Boolean stat5 =` not needed
65         data->ReadReal (num,5,"z",ach,aZ);
66
67         // --- own field : ltx ---
68
69         Standard_Real aLtx;
70         //szv#4:S4163:12Mar99 `Standard_Boolean stat6 =` not needed
71         data->ReadReal (num,6,"ltx",ach,aLtx);
72
73         //--- Initialisation of the read entity ---
74
75
76         ent->Init(aName, aPosition, aX, aY, aZ, aLtx);
77 }
78
79
80 void RWStepShape_RWRightAngularWedge::WriteStep
81         (StepData_StepWriter& SW,
82          const Handle(StepShape_RightAngularWedge)& ent) const
83 {
84
85         // --- inherited field name ---
86
87         SW.Send(ent->Name());
88
89         // --- own field : position ---
90
91         SW.Send(ent->Position());
92
93         // --- own field : x ---
94
95         SW.Send(ent->X());
96
97         // --- own field : y ---
98
99         SW.Send(ent->Y());
100
101         // --- own field : z ---
102
103         SW.Send(ent->Z());
104
105         // --- own field : ltx ---
106
107         SW.Send(ent->Ltx());
108 }
109
110
111 void RWStepShape_RWRightAngularWedge::Share(const Handle(StepShape_RightAngularWedge)& ent, Interface_EntityIterator& iter) const
112 {
113
114         iter.GetOneItem(ent->Position());
115 }
116