--- /dev/null
+#include <RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol.ixx>
+
+#include <StepDimTol_HArray1OfDatumReference.hxx>
+#include <StepDimTol_DatumReference.hxx>
+#include <StepDimTol_GeometricToleranceWithDatumReference.hxx>
+#include <StepDimTol_ModifiedGeometricTolerance.hxx>
+#include <StepDimTol_LimitCondition.hxx>
+
+
+//=======================================================================
+//function : RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol
+//purpose :
+//=======================================================================
+
+RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol::RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol()
+{
+}
+
+
+//=======================================================================
+//function : ReadStep
+//purpose :
+//=======================================================================
+
+void RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol::ReadStep
+ (const Handle(StepData_StepReaderData)& data,
+ const Standard_Integer num0, Handle(Interface_Check)& ach,
+ const Handle(StepDimTol_GeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol)& ent) const
+{
+ Standard_Integer num = 0;//num0;
+ data->NamedForComplex("GEOMETRIC_TOLERANCE",num0,num,ach);
+ if (!data->CheckNbParams(num,4,ach,"geometric_tolerance")) return;
+ // Own fields of GeometricTolerance
+ Handle(TCollection_HAsciiString) aName;
+ data->ReadString (num, 1, "name", ach, aName);
+ Handle(TCollection_HAsciiString) aDescription;
+ data->ReadString (num, 2, "description", ach, aDescription);
+ Handle(StepBasic_MeasureWithUnit) aMagnitude;
+ data->ReadEntity (num, 3, "magnitude", ach, STANDARD_TYPE(StepBasic_MeasureWithUnit), aMagnitude);
+ Handle(StepRepr_ShapeAspect) aTolerancedShapeAspect;
+ data->ReadEntity (num, 4, "toleranced_shape_aspect", ach, STANDARD_TYPE(StepRepr_ShapeAspect), aTolerancedShapeAspect);
+
+ data->NamedForComplex("GEOMETRIC_TOLERANCE_WITH_DATUM_REFERENCE",num0,num,ach);
+ // Own fields of GeometricToleranceWithDatumReference
+ Handle(StepDimTol_HArray1OfDatumReference) aDatumSystem;
+ Standard_Integer sub5 = 0;
+ if ( data->ReadSubList (num, 1, "datum_system", ach, sub5) ) {
+ Standard_Integer nb0 = data->NbParams(sub5);
+ aDatumSystem = new StepDimTol_HArray1OfDatumReference (1, nb0);
+ Standard_Integer num2 = sub5;
+ for ( Standard_Integer i0=1; i0 <= nb0; i0++ ) {
+ Handle(StepDimTol_DatumReference) anIt0;
+ data->ReadEntity (num2, i0, "datum_reference", ach, STANDARD_TYPE(StepDimTol_DatumReference), anIt0);
+ aDatumSystem->SetValue(i0, anIt0);
+ }
+ }
+ // Initialize entity
+ Handle(StepDimTol_GeometricToleranceWithDatumReference) GTWDR =
+ new StepDimTol_GeometricToleranceWithDatumReference;
+ GTWDR->SetDatumSystem(aDatumSystem);
+
+ data->NamedForComplex("MODIFIED_GEOMETRIC_TOLERANCE",num0,num,ach);
+ // Own fields of ModifiedGeometricTolerance
+ StepDimTol_LimitCondition aModifier;
+ if (data->ParamType (num, 1) == Interface_ParamEnum) {
+ Standard_CString text = data->ParamCValue(num, 1);
+ if (strcmp(text, ".MAXIMUM_MATERIAL_CONDITION.")==0) aModifier = StepDimTol_MaximumMaterialCondition;
+ else if (strcmp(text, ".LEAST_MATERIAL_CONDITION.")==0) aModifier = StepDimTol_LeastMaterialCondition;
+ else if (strcmp(text, ".REGARDLESS_OF_FEATURE_SIZE.")==0) aModifier = StepDimTol_RegardlessOfFeatureSize;
+ else ach->AddFail("Parameter in MODIFIED_GEOMETRIC_TOLERANCE has not allowed value");
+ }
+ else ach->AddFail("Parameter in MODIFIED_GEOMETRIC_TOLERANCE is not enumeration");
+ Handle(StepDimTol_ModifiedGeometricTolerance) MGT = new StepDimTol_ModifiedGeometricTolerance;
+ MGT->SetModifier(aModifier);
+
+ // Initialize entity
+ ent->Init(aName, aDescription, aMagnitude, aTolerancedShapeAspect, GTWDR, MGT);
+
+}
+
+
+//=======================================================================
+//function : WriteStep
+//purpose :
+//=======================================================================
+
+void RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol::WriteStep
+ (StepData_StepWriter& SW,
+ const Handle(StepDimTol_GeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol)& ent) const
+{
+ SW.StartEntity("GEOMETRIC_TOLERANCE");
+ SW.Send(ent->Name());
+ SW.Send(ent->Description());
+ SW.Send(ent->Magnitude());
+ SW.Send(ent->TolerancedShapeAspect());
+ SW.StartEntity("GEOMETRIC_TOLERANCE_WITH_DATUM_REFERENCE");
+ SW.OpenSub();
+ for(Standard_Integer i4=1; i4<=ent->GetGeometricToleranceWithDatumReference()->DatumSystem()->Length(); i4++) {
+ Handle(StepDimTol_DatumReference) Var0 =
+ ent->GetGeometricToleranceWithDatumReference()->DatumSystem()->Value(i4);
+ SW.Send(Var0);
+ }
+ SW.CloseSub();
+ SW.StartEntity("MODIFIED_GEOMETRIC_TOLERANCE");
+ switch (ent->GetModifiedGeometricTolerance()->Modifier()) {
+ case StepDimTol_MaximumMaterialCondition: SW.SendEnum(".MAXIMUM_MATERIAL_CONDITION."); break;
+ case StepDimTol_LeastMaterialCondition: SW.SendEnum(".LEAST_MATERIAL_CONDITION."); break;
+ case StepDimTol_RegardlessOfFeatureSize: SW.SendEnum(".REGARDLESS_OF_FEATURE_SIZE."); break;
+ }
+ SW.StartEntity("POSITION_TOLERANCE");
+}
+
+
+//=======================================================================
+//function : Share
+//purpose :
+//=======================================================================
+
+void RWStepDimTol_RWGeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol::Share
+ (const Handle(StepDimTol_GeoTolAndGeoTolWthDatRefAndModGeoTolAndPosTol)& ent,
+ Interface_EntityIterator& iter) const
+{
+ // Own fields of GeometricTolerance
+ iter.AddItem (ent->Magnitude());
+ iter.AddItem (ent->TolerancedShapeAspect());
+ // Own fields of GeometricToleranceWithDatumReference
+ for (Standard_Integer i3=1; i3<=ent->GetGeometricToleranceWithDatumReference()->DatumSystem()->Length(); i3++ ) {
+ Handle(StepDimTol_DatumReference) Var0 = ent->GetGeometricToleranceWithDatumReference()->DatumSystem()->Value(i3);
+ iter.AddItem (Var0);
+ }
+}