1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
3 // This file is part of Open CASCADE Technology software library.
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.
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
15 #include <Interface_Check.hxx>
16 #include <Interface_EntityIterator.hxx>
17 #include <RWStepShape_RWRightCircularCone.hxx>
18 #include <StepData_StepReaderData.hxx>
19 #include <StepData_StepWriter.hxx>
20 #include <StepGeom_Axis1Placement.hxx>
21 #include <StepShape_RightCircularCone.hxx>
23 RWStepShape_RWRightCircularCone::RWStepShape_RWRightCircularCone () {}
25 void RWStepShape_RWRightCircularCone::ReadStep
26 (const Handle(StepData_StepReaderData)& data,
27 const Standard_Integer num,
28 Handle(Interface_Check)& ach,
29 const Handle(StepShape_RightCircularCone)& ent) const
33 // --- Number of Parameter Control ---
35 if (!data->CheckNbParams(num,5,ach,"right_circular_cone")) return;
37 // --- inherited field : name ---
39 Handle(TCollection_HAsciiString) aName;
40 //szv#4:S4163:12Mar99 `Standard_Boolean stat1 =` not needed
41 data->ReadString (num,1,"name",ach,aName);
43 // --- own field : position ---
45 Handle(StepGeom_Axis1Placement) aPosition;
46 //szv#4:S4163:12Mar99 `Standard_Boolean stat2 =` not needed
47 data->ReadEntity(num, 2,"position", ach, STANDARD_TYPE(StepGeom_Axis1Placement), aPosition);
49 // --- own field : height ---
51 Standard_Real aHeight;
52 //szv#4:S4163:12Mar99 `Standard_Boolean stat3 =` not needed
53 data->ReadReal (num,3,"height",ach,aHeight);
55 // --- own field : radius ---
57 Standard_Real aRadius;
58 //szv#4:S4163:12Mar99 `Standard_Boolean stat4 =` not needed
59 data->ReadReal (num,4,"radius",ach,aRadius);
61 // --- own field : semiAngle ---
63 Standard_Real aSemiAngle;
64 //szv#4:S4163:12Mar99 `Standard_Boolean stat5 =` not needed
65 data->ReadReal (num,5,"semi_angle",ach,aSemiAngle);
67 //--- Initialisation of the read entity ---
70 ent->Init(aName, aPosition, aHeight, aRadius, aSemiAngle);
74 void RWStepShape_RWRightCircularCone::WriteStep
75 (StepData_StepWriter& SW,
76 const Handle(StepShape_RightCircularCone)& ent) const
79 // --- inherited field name ---
83 // --- own field : position ---
85 SW.Send(ent->Position());
87 // --- own field : height ---
89 SW.Send(ent->Height());
91 // --- own field : radius ---
93 SW.Send(ent->Radius());
95 // --- own field : semiAngle ---
97 SW.Send(ent->SemiAngle());
101 void RWStepShape_RWRightCircularCone::Share(const Handle(StepShape_RightCircularCone)& ent, Interface_EntityIterator& iter) const
104 iter.GetOneItem(ent->Position());