X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSMESHDS%2FSMESHDS_SubMesh.hxx;h=ac3cd1c3f81b79ea618a963aa2ccb5c2983dda37;hb=87fd8ca50b1fe004fc046c66c5b5df6199861981;hp=53802ecb4b6ac68557c070646ab06f898e5707de;hpb=2d46bce2985c40bfac0593abad88d590a8efca48;p=modules%2Fsmesh.git diff --git a/src/SMESHDS/SMESHDS_SubMesh.hxx b/src/SMESHDS/SMESHDS_SubMesh.hxx index 53802ecb4..ac3cd1c3f 100644 --- a/src/SMESHDS/SMESHDS_SubMesh.hxx +++ b/src/SMESHDS/SMESHDS_SubMesh.hxx @@ -28,33 +28,42 @@ #define _SMESHDS_SubMesh_HeaderFile #include "SMDS_Mesh.hxx" -#include #include -using namespace std; +#if defined WNT && defined WIN32 && defined SMESHDS_EXPORTS +#define SMESHDS_WNT_EXPORT __declspec( dllexport ) +#else +#define SMESHDS_WNT_EXPORT +#endif -class SMESHDS_SubMesh +class SMESHDS_WNT_EXPORT SMESHDS_SubMesh { - public: - SMESHDS_SubMesh(const SMDS_Mesh * M); - void AddElement(const SMDS_MeshElement * ME); - void RemoveElement(const SMDS_MeshElement * ME); - void AddNode(const SMDS_MeshNode * ME); - void RemoveNode(const SMDS_MeshNode * ME); - int NbElements() const; - const set & GetElements(); - const vector & GetIDElements(); - int NbNodes() const; - const set & GetNodes() const; - const vector & GetIDNodes(); - ~SMESHDS_SubMesh(); - private: - const SMDS_Mesh * myMesh; - set myElements; - set myNodes; - bool myListOfEltIDIsUpdate; - vector myListOfEltID; - bool myListOfNodeIDIsUpdate; - vector myListOfNodeID; + public: + + bool IsComplexSubmesh() const { return !mySubMeshes.empty(); } + + // if !IsComplexSubmesh() + void AddElement(const SMDS_MeshElement * ME); + bool RemoveElement(const SMDS_MeshElement * ME); // ret true if ME was in + void AddNode(const SMDS_MeshNode * ME); + bool RemoveNode(const SMDS_MeshNode * ME); // ret true if ME was in + + // if IsComplexSubmesh() + void AddSubMesh( const SMESHDS_SubMesh* theSubMesh ); + bool RemoveSubMesh( const SMESHDS_SubMesh* theSubMesh ); + bool ContainsSubMesh( const SMESHDS_SubMesh* theSubMesh ) const; + + // for both types + int NbElements() const; + SMDS_ElemIteratorPtr GetElements() const; + int NbNodes() const; + SMDS_NodeIteratorPtr GetNodes() const; + bool Contains(const SMDS_MeshElement * ME) const; // check if elem or node is in + + private: + //const SMDS_Mesh * myMesh; + std::set myElements; + std::set myNodes; + std::set mySubMeshes; }; #endif