1 // SMESH SMDS : implementaion of Salome mesh data structure
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
24 // File : SMDS_MeshNode.hxx
27 #ifndef _SMDS_MeshNode_HeaderFile
28 #define _SMDS_MeshNode_HeaderFile
30 #ifndef _Standard_HeaderFile
31 #include <Standard.hxx>
33 #ifndef _Handle_SMDS_MeshNode_HeaderFile
34 #include "Handle_SMDS_MeshNode.hxx"
37 #ifndef _gp_Pnt_HeaderFile
40 #ifndef _SMDS_ListOfMeshElement_HeaderFile
41 #include "SMDS_ListOfMeshElement.hxx"
43 #ifndef _Handle_SMDS_Position_HeaderFile
44 #include "Handle_SMDS_Position.hxx"
46 #ifndef _SMDS_MeshElement_HeaderFile
47 #include "SMDS_MeshElement.hxx"
49 #ifndef _Standard_Integer_HeaderFile
50 #include <Standard_Integer.hxx>
52 #ifndef _Standard_Real_HeaderFile
53 #include <Standard_Real.hxx>
55 #ifndef _Standard_OStream_HeaderFile
56 #include <Standard_OStream.hxx>
58 #ifndef _Handle_SMDS_MeshElement_HeaderFile
59 #include "Handle_SMDS_MeshElement.hxx"
63 class SMDS_MeshElement;
64 class SMDS_ListOfMeshElement;
67 class SMDS_MeshNode : public SMDS_MeshElement {
71 inline void* operator new(size_t,void* anAddress)
75 inline void* operator new(size_t size)
77 return Standard::Allocate(size);
79 inline void operator delete(void *anAddress)
81 if (anAddress) Standard::Free((Standard_Address&)anAddress);
83 // inline void operator delete(void *anAddress, size_t size)
85 // if (anAddress) Standard::Free((Standard_Address&)anAddress,size);
89 Standard_EXPORT SMDS_MeshNode(const Standard_Integer ID,const Standard_Real x,const Standard_Real y,const Standard_Real z);
90 Standard_EXPORT void Print(Standard_OStream& OS) const;
91 Standard_EXPORT inline Standard_Integer GetKey() const;
92 Standard_EXPORT inline Standard_Real X() const;
93 Standard_EXPORT inline Standard_Real Y() const;
94 Standard_EXPORT inline Standard_Real Z() const;
95 Standard_EXPORT inline gp_Pnt Pnt() const;
96 Standard_EXPORT inline void SetPnt(const gp_Pnt& P) ;
97 Standard_EXPORT inline void AddInverseElement(const Handle(SMDS_MeshElement)& ME) ;
98 Standard_EXPORT void RemoveInverseElement(const Handle(SMDS_MeshElement)& parent) ;
99 Standard_EXPORT inline const SMDS_ListOfMeshElement& InverseElements() const;
100 Standard_EXPORT inline void ClearInverseElements() ;
101 Standard_EXPORT void SetPosition(const Handle(SMDS_Position)& aPos) ;
102 Standard_EXPORT Handle_SMDS_Position GetPosition() const;
103 Standard_EXPORT ~SMDS_MeshNode();
110 Standard_EXPORT friend Handle_Standard_Type& SMDS_MeshNode_Type_();
111 Standard_EXPORT const Handle(Standard_Type)& DynamicType() const;
112 Standard_EXPORT Standard_Boolean IsKind(const Handle(Standard_Type)&) const;
133 SMDS_ListOfMeshElement myInverseElements;
134 Handle_SMDS_Position myPosition;
140 #include "SMDS_MeshNode.lxx"
144 // other inline functions and methods (like "C++: function call" methods)