Salome HOME
Merge from V6_3_BR 06/06/2011
[modules/smesh.git] / src / SMDS / SMDS_Mesh0DElement.hxx
1 // Copyright (C) 2007-2011  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 // Lesser General Public License for more details.
12 //
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
16 //
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 //
19
20 //  SMESH SMDS : implementaion of Salome mesh data structure
21 //  File   : SMDS_Mesh0DElement.hxx
22 //  Module : SMESH
23 //
24 #ifndef _SMDS_Mesh0DElement_HeaderFile
25 #define _SMDS_Mesh0DElement_HeaderFile
26
27 #include "SMESH_SMDS.hxx"
28
29 #include "SMDS_MeshCell.hxx"
30
31 #include <iostream>
32
33 class SMDS_EXPORT SMDS_Mesh0DElement: public SMDS_MeshCell
34 {
35  public:
36   SMDS_Mesh0DElement (const SMDS_MeshNode * node);
37   bool ChangeNode (const SMDS_MeshNode * node);
38   virtual bool ChangeNodes(const SMDS_MeshNode* nodes[], const int nbNodes) {return false;};
39   void Print (std::ostream & OS) const;
40
41   SMDSAbs_ElementType GetType() const;
42   virtual vtkIdType GetVtkType() const;
43   SMDSAbs_EntityType  GetEntityType() const {return SMDSEntity_0D;}
44   int NbNodes() const;
45   int NbEdges() const;
46   friend bool operator< (const SMDS_Mesh0DElement& e1, const SMDS_Mesh0DElement& e2);
47
48   /*!
49    * \brief Return node by its index
50    * \param ind - node index
51    * \retval const SMDS_MeshNode* - the node
52    */
53   virtual const SMDS_MeshNode* GetNode (const int ind) const;
54
55  protected:
56   SMDS_ElemIteratorPtr elementsIterator (SMDSAbs_ElementType type) const;
57
58  protected:
59   const SMDS_MeshNode* myNode;
60 };
61
62 #endif