Integration of OCCT 6.5.0 from SVN
[occt.git] / src / RWStepRepr / RWStepRepr_RWReprItemAndLengthMeasureWithUnit.cxx
diff --git a/src/RWStepRepr/RWStepRepr_RWReprItemAndLengthMeasureWithUnit.cxx b/src/RWStepRepr/RWStepRepr_RWReprItemAndLengthMeasureWithUnit.cxx
new file mode 100755 (executable)
index 0000000..0338881
--- /dev/null
@@ -0,0 +1,68 @@
+#include <RWStepRepr_RWReprItemAndLengthMeasureWithUnit.ixx>
+
+#include <StepBasic_MeasureValueMember.hxx>
+#include <StepBasic_Unit.hxx>
+#include <StepBasic_MeasureWithUnit.hxx>
+
+
+//=======================================================================
+//function : RWSteprepr_RWReprItemAndLengthMeasureWithUnit
+//purpose  : 
+//=======================================================================
+
+RWStepRepr_RWReprItemAndLengthMeasureWithUnit::RWStepRepr_RWReprItemAndLengthMeasureWithUnit() {}
+
+
+//=======================================================================
+//function : ReadStep
+//purpose  : 
+//=======================================================================
+
+void RWStepRepr_RWReprItemAndLengthMeasureWithUnit::ReadStep
+       (const Handle(StepData_StepReaderData)& data,
+        const Standard_Integer num0,
+        Handle(Interface_Check)& ach,
+        const Handle(StepRepr_ReprItemAndLengthMeasureWithUnit)& ent) const
+{
+  Standard_Integer num = 0;//num0;
+  data->NamedForComplex("MEASURE_WITH_UNIT",num0,num,ach);
+  if (!data->CheckNbParams(num,2,ach,"measure_with_unit")) return;
+  // --- own field : valueComponent ---
+  Handle(StepBasic_MeasureValueMember) mvc = new StepBasic_MeasureValueMember;
+  data->ReadMember (num,1, "value_component", ach, mvc);
+  // --- own field : unitComponent ---
+  StepBasic_Unit aUnitComponent;
+  data->ReadEntity(num, 2,"unit_component", ach, aUnitComponent);
+  Handle(StepBasic_MeasureWithUnit) aMeasureWithUnit = new StepBasic_MeasureWithUnit;
+  aMeasureWithUnit->Init(mvc, aUnitComponent);
+
+  data->NamedForComplex("REPRESENTATION_ITEM",num0,num,ach);
+  if (!data->CheckNbParams(num,1,ach,"representation_item")) return;
+  // --- own field : name ---
+  Handle(TCollection_HAsciiString) aName;
+  data->ReadString (num,1,"name",ach,aName);
+  Handle(StepRepr_RepresentationItem) aReprItem = new StepRepr_RepresentationItem;
+  aReprItem->Init(aName);
+
+  //--- Initialisation of the read entity ---
+  ent->Init(aMeasureWithUnit,aReprItem);
+}
+
+
+//=======================================================================
+//function : WriteStep
+//purpose  : 
+//=======================================================================
+
+void RWStepRepr_RWReprItemAndLengthMeasureWithUnit::WriteStep
+       (StepData_StepWriter& SW,
+        const Handle(StepRepr_ReprItemAndLengthMeasureWithUnit)& ent) const
+{
+  SW.StartEntity("LENGTH_MEASURE_WITH_UNIT");
+  SW.StartEntity("MEASURE_REPRESENTATION_ITEM");
+  SW.StartEntity("MEASURE_WITH_UNIT");
+  SW.Send(ent->GetMeasureWithUnit()->ValueComponentMember());
+  SW.Send(ent->GetMeasureWithUnit()->UnitComponent().Value());
+  SW.StartEntity("REPRESENTATION_ITEM");
+  SW.Send(ent->Name());
+}