X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FDriverMED%2FDriverMED_W_SMESHDS_Mesh.h;h=10a46bc69342e1effdbc83c989f7895fca32dea1;hb=dacd89c7dfc779f4a8249ff08ca15f7b963408a5;hp=7c02b40f02da34f38c9d55cc9f7ddc9e2401aae1;hpb=bd8f1aee7c78f7d2eb82bd4fec5e08c9e3d280ce;p=modules%2Fsmesh.git diff --git a/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h b/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h index 7c02b40f0..10a46bc69 100644 --- a/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h +++ b/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h @@ -1,4 +1,4 @@ -// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE +// Copyright (C) 2007-2022 CEA/DEN, EDF R&D, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS @@ -6,7 +6,7 @@ // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either -// version 2.1 of the License. +// version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -30,28 +30,34 @@ #include "SMESH_DriverMED.hxx" #include "Driver_SMESHDS_Mesh.h" -#include "MED_Factory.hxx" +//#include "MED_Common.hxx" #include #include #include +#include class SMESHDS_Mesh; class SMESHDS_GroupBase; class SMESHDS_SubMesh; +class SMDS_MeshElement; +/*! + * \brief Write a mesh to a MED file + */ class MESHDRIVERMED_EXPORT DriverMED_W_SMESHDS_Mesh: public Driver_SMESHDS_Mesh { public: DriverMED_W_SMESHDS_Mesh(); - virtual void SetFile(const std::string& theFileName); - void SetFile(const std::string& theFileName, MED::EVersion theId); - static std::string GetVersionString(const MED::EVersion theVersion, int theNbDigits=2); + void SetFile(const std::string& theFileName, int theVersion=-1); + void SetAutoDimension(bool toFindOutDimension) { myAutoDimension = toFindOutDimension; } + void SetZTolerance(double tol) { myZTolerance = tol; } + void SetSaveNumbers(bool toSave) { mySaveNumbers = toSave; } + + static std::string GetVersionString(int theMinor, int theNbDigits=2); - /*! sets file name; only for usage with Add(), not Write() - */ void AddGroupOfNodes(); void AddGroupOfEdges(); void AddGroupOfFaces(); @@ -64,25 +70,49 @@ class MESHDRIVERMED_EXPORT DriverMED_W_SMESHDS_Mesh: public Driver_SMESHDS_Mesh void AddGroup(SMESHDS_GroupBase * theGroup); void AddAllSubMeshes(); void AddSubMesh(SMESHDS_SubMesh* theSubMesh, int theID); + void AddODOnVertices(bool toAdd) { myAddODOnVertices = toAdd; } + + static bool getNodesOfMissing0DOnVert(SMESHDS_Mesh* mesh, + std::vector& nodes); /*! add one mesh */ - virtual Status Perform(); + Status Perform() override; + + template + Driver_Mesh::Status PerformInternal(LowLevelWriter myMed); private: - MED::PWrapper myMed; std::list myGroups; - bool myAllSubMeshes; - std::map mySubMeshes; - bool myDoGroupOfNodes; - bool myDoGroupOfEdges; - bool myDoGroupOfFaces; - bool myDoGroupOfVolumes; - bool myDoGroupOf0DElems; - bool myDoGroupOfBalls; + bool myAllSubMeshes; + std::vector mySubMeshes; + bool myDoGroupOfNodes; + bool myDoGroupOfEdges; + bool myDoGroupOfFaces; + bool myDoGroupOfVolumes; + bool myDoGroupOf0DElems; + bool myDoGroupOfBalls; + bool myAutoDimension; + bool myAddODOnVertices; + bool myDoAllInGroups; + int myVersion; + double myZTolerance; + bool mySaveNumbers; }; +#include "MEDCouplingMemArray.hxx" -#endif +/*! + * \brief Write a mesh to a MEDCoupling DS + */ +class MESHDRIVERMED_EXPORT DriverMED_W_SMESHDS_Mesh_Mem : public DriverMED_W_SMESHDS_Mesh +{ +public: + Status Perform() override; + MEDCoupling::MCAuto getData() { return _data; } +private: + MEDCoupling::MCAuto _data; +}; +#endif