X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FDriverMED%2FDriverMED_W_SMESHDS_Mesh.h;h=899c4375bd13644293b859d0034718421873a88a;hb=85b1cfc1f07d0b93d88803c6c0ccadf8f3349719;hp=ec2ad8d862f4df6c44c1f5db5562542e31c0ab7f;hpb=4791f5b30ea7a9c1247aa551750dc71cb83b99aa;p=modules%2Fsmesh.git diff --git a/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h b/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h index ec2ad8d86..899c4375b 100644 --- a/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h +++ b/src/DriverMED/DriverMED_W_SMESHDS_Mesh.h @@ -17,7 +17,7 @@ // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // // // @@ -27,37 +27,60 @@ #ifndef _INCLUDE_DRIVERMED_W_SMESHDS_MESH #define _INCLUDE_DRIVERMED_W_SMESHDS_MESH -#include "SMESHDS_Mesh.hxx" -#include "Mesh_Writer.h" +#include "SMESH_DriverMED.hxx" + +#include "Driver_SMESHDS_Mesh.h" +#include "MED_Factory.hxx" #include +#include +#include + +class SMESHDS_Mesh; +class SMESHDS_GroupBase; +class SMESHDS_SubMesh; -extern "C" +class MESHDRIVERMED_EXPORT DriverMED_W_SMESHDS_Mesh: public Driver_SMESHDS_Mesh { -#include -} + public: -class DriverMED_W_SMESHDS_Mesh : public Mesh_Writer { + DriverMED_W_SMESHDS_Mesh(); - public : - DriverMED_W_SMESHDS_Mesh(); - ~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 Add(); - void Write(); - void SetMesh(Handle(SMDS_Mesh)& aMesh); - void SetFile(string); + /*! sets file name; only for usage with Add(), not Write() + */ + void AddGroupOfNodes(); + void AddGroupOfEdges(); + void AddGroupOfFaces(); + void AddGroupOfVolumes(); - void SetFileId(med_idt); - void SetMeshId(int); + /*! functions to prepare adding one mesh + */ + void SetMeshName(const std::string& theMeshName); + void AddGroup(SMESHDS_GroupBase * theGroup); + void AddAllSubMeshes(); + void AddSubMesh(SMESHDS_SubMesh* theSubMesh, int theID); - void CreateFamily(char*, char*, int, med_int); + /*! add one mesh + */ + virtual Status Perform(); -private : - Handle_SMDS_Mesh myMesh; - string myFile; - med_idt myFileId; - int myMeshId; + private: + MED::PWrapper myMed; + std::string myMeshName; + std::list myGroups; + bool myAllSubMeshes; + std::map mySubMeshes; + bool myDoGroupOfNodes; + bool myDoGroupOfEdges; + bool myDoGroupOfFaces; + bool myDoGroupOfVolumes; }; + + #endif +