#include #include #include #include #include // --- Enum : TransitionCode --- static TCollection_AsciiString tcDiscontinuous(".DISCONTINUOUS."); static TCollection_AsciiString tcContSameGradientSameCurvature(".CONT_SAME_GRADIENT_SAME_CURVATURE."); static TCollection_AsciiString tcContSameGradient(".CONT_SAME_GRADIENT."); static TCollection_AsciiString tcContinuous(".CONTINUOUS."); RWStepGeom_RWReparametrisedCompositeCurveSegment::RWStepGeom_RWReparametrisedCompositeCurveSegment () {} void RWStepGeom_RWReparametrisedCompositeCurveSegment::ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepGeom_ReparametrisedCompositeCurveSegment)& ent) const { // --- Number of Parameter Control --- if (!data->CheckNbParams(num,4,ach,"reparametrised_composite_curve_segment")) return; // --- inherited field : transition --- StepGeom_TransitionCode aTransition = StepGeom_tcDiscontinuous; if (data->ParamType(num,1) == Interface_ParamEnum) { Standard_CString text = data->ParamCValue(num,1); if (tcDiscontinuous.IsEqual(text)) aTransition = StepGeom_tcDiscontinuous; else if (tcContSameGradientSameCurvature.IsEqual(text)) aTransition = StepGeom_tcContSameGradientSameCurvature; else if (tcContSameGradient.IsEqual(text)) aTransition = StepGeom_tcContSameGradient; else if (tcContinuous.IsEqual(text)) aTransition = StepGeom_tcContinuous; else ach->AddFail("Enumeration transition_code has not an allowed value"); } else ach->AddFail("Parameter #1 (transition) is not an enumeration"); // --- inherited field : sameSense --- Standard_Boolean aSameSense; //szv#4:S4163:12Mar99 `Standard_Boolean stat2 =` not needed data->ReadBoolean (num,2,"same_sense",ach,aSameSense); // --- inherited field : parentCurve --- Handle(StepGeom_Curve) aParentCurve; //szv#4:S4163:12Mar99 `Standard_Boolean stat3 =` not needed data->ReadEntity(num, 3,"parent_curve", ach, STANDARD_TYPE(StepGeom_Curve), aParentCurve); // --- own field : paramLength --- Standard_Real aParamLength; //szv#4:S4163:12Mar99 `Standard_Boolean stat4 =` not needed data->ReadReal (num,4,"param_length",ach,aParamLength); //--- Initialisation of the read entity --- ent->Init(aTransition, aSameSense, aParentCurve, aParamLength); } void RWStepGeom_RWReparametrisedCompositeCurveSegment::WriteStep (StepData_StepWriter& SW, const Handle(StepGeom_ReparametrisedCompositeCurveSegment)& ent) const { // --- inherited field transition --- switch(ent->Transition()) { case StepGeom_tcDiscontinuous : SW.SendEnum (tcDiscontinuous); break; case StepGeom_tcContSameGradientSameCurvature : SW.SendEnum (tcContSameGradientSameCurvature); break; case StepGeom_tcContSameGradient : SW.SendEnum (tcContSameGradient); break; case StepGeom_tcContinuous : SW.SendEnum (tcContinuous); break; } // --- inherited field sameSense --- SW.SendBoolean(ent->SameSense()); // --- inherited field parentCurve --- SW.Send(ent->ParentCurve()); // --- own field : paramLength --- SW.Send(ent->ParamLength()); } void RWStepGeom_RWReparametrisedCompositeCurveSegment::Share(const Handle(StepGeom_ReparametrisedCompositeCurveSegment)& ent, Interface_EntityIterator& iter) const { iter.GetOneItem(ent->ParentCurve()); }