Integration of OCCT 6.5.0 from SVN
[occt.git] / src / IGESDimen / IGESDimen_ReadWriteModule.cxx
diff --git a/src/IGESDimen/IGESDimen_ReadWriteModule.cxx b/src/IGESDimen/IGESDimen_ReadWriteModule.cxx
new file mode 100755 (executable)
index 0000000..519e32e
--- /dev/null
@@ -0,0 +1,446 @@
+#include <IGESDimen_ReadWriteModule.ixx>
+#include <Interface_Macros.hxx>
+
+#include <IGESDimen_AngularDimension.hxx>
+#include <IGESDimen_BasicDimension.hxx>
+#include <IGESDimen_CenterLine.hxx>
+#include <IGESDimen_CurveDimension.hxx>
+#include <IGESDimen_DiameterDimension.hxx>
+#include <IGESDimen_DimensionDisplayData.hxx>
+#include <IGESDimen_DimensionTolerance.hxx>
+#include <IGESDimen_DimensionUnits.hxx>
+#include <IGESDimen_DimensionedGeometry.hxx>
+#include <IGESDimen_FlagNote.hxx>
+#include <IGESDimen_GeneralLabel.hxx>
+#include <IGESDimen_GeneralNote.hxx>
+#include <IGESDimen_GeneralSymbol.hxx>
+#include <IGESDimen_LeaderArrow.hxx>
+#include <IGESDimen_LinearDimension.hxx>
+#include <IGESDimen_NewDimensionedGeometry.hxx>
+#include <IGESDimen_NewGeneralNote.hxx>
+#include <IGESDimen_OrdinateDimension.hxx>
+#include <IGESDimen_PointDimension.hxx>
+#include <IGESDimen_RadiusDimension.hxx>
+#include <IGESDimen_Section.hxx>
+#include <IGESDimen_SectionedArea.hxx>
+#include <IGESDimen_WitnessLine.hxx>
+
+#include <IGESDimen_ToolAngularDimension.hxx>
+#include <IGESDimen_ToolBasicDimension.hxx>
+#include <IGESDimen_ToolCenterLine.hxx>
+#include <IGESDimen_ToolCurveDimension.hxx>
+#include <IGESDimen_ToolDiameterDimension.hxx>
+#include <IGESDimen_ToolDimensionDisplayData.hxx>
+#include <IGESDimen_ToolDimensionTolerance.hxx>
+#include <IGESDimen_ToolDimensionUnits.hxx>
+#include <IGESDimen_ToolDimensionedGeometry.hxx>
+#include <IGESDimen_ToolFlagNote.hxx>
+#include <IGESDimen_ToolGeneralLabel.hxx>
+#include <IGESDimen_ToolGeneralNote.hxx>
+#include <IGESDimen_ToolGeneralSymbol.hxx>
+#include <IGESDimen_ToolLeaderArrow.hxx>
+#include <IGESDimen_ToolLinearDimension.hxx>
+#include <IGESDimen_ToolNewDimensionedGeometry.hxx>
+#include <IGESDimen_ToolNewGeneralNote.hxx>
+#include <IGESDimen_ToolOrdinateDimension.hxx>
+#include <IGESDimen_ToolPointDimension.hxx>
+#include <IGESDimen_ToolRadiusDimension.hxx>
+#include <IGESDimen_ToolSection.hxx>
+#include <IGESDimen_ToolSectionedArea.hxx>
+#include <IGESDimen_ToolWitnessLine.hxx>
+
+
+
+//  Each Module is attached to a Protocol : it must interprete Case Numbers
+//  (arguments <CN> of various methods) in accordance to values returned by
+//  the method TypeNumber from this Protocol
+
+
+    IGESDimen_ReadWriteModule::IGESDimen_ReadWriteModule ()    {  }
+
+
+    Standard_Integer  IGESDimen_ReadWriteModule::CaseIGES
+  (const Standard_Integer typenum, const Standard_Integer formnum) const 
+{
+  switch (typenum) {
+    case 106 :
+      if      (formnum == 20 || formnum == 21) return  3;
+      else if (formnum  > 30 && formnum  < 40) return 21;
+      else if (formnum == 40)                  return 23;
+      break;
+    case 202 : return  1;
+    case 204 : return  4;
+    case 206 : return  5;
+    case 208 : return 10;
+    case 210 : return 11;
+    case 212 : return 12;
+    case 213 : return 17;
+    case 214 : return 14;
+    case 216 : return 15;
+    case 218 : return 18;
+    case 220 : return 19;
+    case 222 : return 20;
+    case 228 : return 13;
+    case 230 : return 22;
+    case 402 :
+      switch (formnum) {
+        case 13 : return  9;
+        case 21 : return 16;
+       default : break;
+      }
+      break;
+    case 406 :
+      switch (formnum) {
+        case 28 : return  8;
+        case 29 : return  7;
+        case 30 : return  6;
+        case 31 : return  2;
+       default : break;
+      }
+      break;
+    default : break;
+  }
+  return 0;
+}
+
+
+    void  IGESDimen_ReadWriteModule::ReadOwnParams
+  (const Standard_Integer CN, const Handle(IGESData_IGESEntity)& ent,
+   const Handle(IGESData_IGESReaderData)& IR, IGESData_ParamReader& PR) const 
+{
+  switch (CN) {
+    case  1 : {
+      DeclareAndCast(IGESDimen_AngularDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolAngularDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  2 : {
+      DeclareAndCast(IGESDimen_BasicDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolBasicDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  3 : {
+      DeclareAndCast(IGESDimen_CenterLine,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolCenterLine tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  4 : {
+      DeclareAndCast(IGESDimen_CurveDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolCurveDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  5 : {
+      DeclareAndCast(IGESDimen_DiameterDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDiameterDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  6 : {
+      DeclareAndCast(IGESDimen_DimensionDisplayData,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionDisplayData tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  7 : {
+      DeclareAndCast(IGESDimen_DimensionTolerance,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionTolerance tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  8 : {
+      DeclareAndCast(IGESDimen_DimensionUnits,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionUnits tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case  9 : {
+      DeclareAndCast(IGESDimen_DimensionedGeometry,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionedGeometry tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 10 : {
+      DeclareAndCast(IGESDimen_FlagNote,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolFlagNote tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 11 : {
+      DeclareAndCast(IGESDimen_GeneralLabel,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolGeneralLabel tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 12 : {
+      DeclareAndCast(IGESDimen_GeneralNote,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolGeneralNote tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 13 : {
+      DeclareAndCast(IGESDimen_GeneralSymbol,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolGeneralSymbol tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 14 : {
+      DeclareAndCast(IGESDimen_LeaderArrow,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolLeaderArrow tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 15 : {
+      DeclareAndCast(IGESDimen_LinearDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolLinearDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 16 : {
+      DeclareAndCast(IGESDimen_NewDimensionedGeometry,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolNewDimensionedGeometry tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 17 : {
+      DeclareAndCast(IGESDimen_NewGeneralNote,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolNewGeneralNote tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 18 : {
+      DeclareAndCast(IGESDimen_OrdinateDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolOrdinateDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 19 : {
+      DeclareAndCast(IGESDimen_PointDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolPointDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 20 : {
+      DeclareAndCast(IGESDimen_RadiusDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolRadiusDimension tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 21 : {
+      DeclareAndCast(IGESDimen_Section,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolSection tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 22 : {
+      DeclareAndCast(IGESDimen_SectionedArea,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolSectionedArea tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    case 23 : {
+      DeclareAndCast(IGESDimen_WitnessLine,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolWitnessLine tool;
+      tool.ReadOwnParams(anent,IR,PR);
+    }
+      break;
+    default : break;
+  }
+}
+
+
+    void  IGESDimen_ReadWriteModule::WriteOwnParams
+  (const Standard_Integer CN,  const Handle(IGESData_IGESEntity)& ent,
+   IGESData_IGESWriter& IW) const
+{
+  switch (CN) {
+    case  1 : {
+      DeclareAndCast(IGESDimen_AngularDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolAngularDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  2 : {
+      DeclareAndCast(IGESDimen_BasicDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolBasicDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  3 : {
+      DeclareAndCast(IGESDimen_CenterLine,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolCenterLine tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  4 : {
+      DeclareAndCast(IGESDimen_CurveDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolCurveDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  5 : {
+      DeclareAndCast(IGESDimen_DiameterDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDiameterDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  6 : {
+      DeclareAndCast(IGESDimen_DimensionDisplayData,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionDisplayData tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  7 : {
+      DeclareAndCast(IGESDimen_DimensionTolerance,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionTolerance tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  8 : {
+      DeclareAndCast(IGESDimen_DimensionUnits,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionUnits tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case  9 : {
+      DeclareAndCast(IGESDimen_DimensionedGeometry,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolDimensionedGeometry tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 10 : {
+      DeclareAndCast(IGESDimen_FlagNote,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolFlagNote tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 11 : {
+      DeclareAndCast(IGESDimen_GeneralLabel,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolGeneralLabel tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 12 : {
+      DeclareAndCast(IGESDimen_GeneralNote,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolGeneralNote tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 13 : {
+      DeclareAndCast(IGESDimen_GeneralSymbol,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolGeneralSymbol tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 14 : {
+      DeclareAndCast(IGESDimen_LeaderArrow,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolLeaderArrow tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 15 : {
+      DeclareAndCast(IGESDimen_LinearDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolLinearDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 16 : {
+      DeclareAndCast(IGESDimen_NewDimensionedGeometry,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolNewDimensionedGeometry tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 17 : {
+      DeclareAndCast(IGESDimen_NewGeneralNote,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolNewGeneralNote tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 18 : {
+      DeclareAndCast(IGESDimen_OrdinateDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolOrdinateDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 19 : {
+      DeclareAndCast(IGESDimen_PointDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolPointDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 20 : {
+      DeclareAndCast(IGESDimen_RadiusDimension,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolRadiusDimension tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 21 : {
+      DeclareAndCast(IGESDimen_Section,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolSection tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 22 : {
+      DeclareAndCast(IGESDimen_SectionedArea,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolSectionedArea tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    case 23 : {
+      DeclareAndCast(IGESDimen_WitnessLine,anent,ent);
+      if (anent.IsNull()) return;
+      IGESDimen_ToolWitnessLine tool;
+      tool.WriteOwnParams(anent,IW);
+    }
+      break;
+    default : break;
+  }
+}