X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FSMDS%2FSMDS_MeshNode.hxx;h=f53630705b57fff437725290405a7d9307216d49;hp=4d9c35d2e885c35a70598f577dafeade5b21dfbb;hb=253bd8edea0f44d01e65f1fb085d04428544bd14;hpb=c6248ade999eaffe5bbddbcaea61487811aa4e0c diff --git a/src/SMDS/SMDS_MeshNode.hxx b/src/SMDS/SMDS_MeshNode.hxx index 4d9c35d2e..f53630705 100644 --- a/src/SMDS/SMDS_MeshNode.hxx +++ b/src/SMDS/SMDS_MeshNode.hxx @@ -1,137 +1,68 @@ -// File generated by CPPExt (Transient) +// SMESH SMDS : implementaion of Salome mesh data structure // -// Copyright (C) 1991,1995 by -// -// MATRA DATAVISION, FRANCE -// -// This software is furnished in accordance with the terms and conditions -// of the contract and with the inclusion of the above copyright notice. -// This software or any other copy thereof may not be provided or otherwise -// be made available to any other person. No title to an ownership of the -// software is hereby transferred. -// -// At the termination of the contract, the software and all copies of this -// software must be deleted. +// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, +// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS +// +// 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. +// +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// 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 // +// +// +// File : SMDS_MeshNode.hxx +// Module : SMESH + #ifndef _SMDS_MeshNode_HeaderFile #define _SMDS_MeshNode_HeaderFile -#ifndef _Standard_HeaderFile -#include -#endif -#ifndef _Handle_SMDS_MeshNode_HeaderFile -#include "Handle_SMDS_MeshNode.hxx" -#endif - -#ifndef _gp_Pnt_HeaderFile -#include -#endif -#ifndef _SMDS_ListOfMeshElement_HeaderFile -#include "SMDS_ListOfMeshElement.hxx" -#endif -#ifndef _Handle_SMDS_Position_HeaderFile -#include "Handle_SMDS_Position.hxx" -#endif -#ifndef _SMDS_MeshElement_HeaderFile #include "SMDS_MeshElement.hxx" -#endif -#ifndef _Standard_Integer_HeaderFile -#include -#endif -#ifndef _Standard_Real_HeaderFile -#include -#endif -#ifndef _Standard_OStream_HeaderFile -#include -#endif -#ifndef _Handle_SMDS_MeshElement_HeaderFile -#include "Handle_SMDS_MeshElement.hxx" -#endif -class SMDS_Position; -class gp_Pnt; -class SMDS_MeshElement; -class SMDS_ListOfMeshElement; - - -class SMDS_MeshNode : public SMDS_MeshElement { - -public: - - inline void* operator new(size_t,void* anAddress) - { - return anAddress; - } - inline void* operator new(size_t size) - { - return Standard::Allocate(size); - } - inline void operator delete(void *anAddress) - { - if (anAddress) Standard::Free((Standard_Address&)anAddress); - } -// inline void operator delete(void *anAddress, size_t size) -// { -// if (anAddress) Standard::Free((Standard_Address&)anAddress,size); -// } - // Methods PUBLIC - // -Standard_EXPORT SMDS_MeshNode(const Standard_Integer ID,const Standard_Real x,const Standard_Real y,const Standard_Real z); -Standard_EXPORT void Print(Standard_OStream& OS) const; -Standard_EXPORT inline Standard_Integer GetKey() const; -Standard_EXPORT inline Standard_Real X() const; -Standard_EXPORT inline Standard_Real Y() const; -Standard_EXPORT inline Standard_Real Z() const; -Standard_EXPORT inline gp_Pnt Pnt() const; -Standard_EXPORT inline void SetPnt(const gp_Pnt& P) ; -Standard_EXPORT inline void AddInverseElement(const Handle(SMDS_MeshElement)& ME) ; -Standard_EXPORT void RemoveInverseElement(const Handle(SMDS_MeshElement)& parent) ; -Standard_EXPORT inline const SMDS_ListOfMeshElement& InverseElements() const; -Standard_EXPORT inline void ClearInverseElements() ; -Standard_EXPORT void SetPosition(const Handle(SMDS_Position)& aPos) ; -Standard_EXPORT Handle_SMDS_Position GetPosition() const; -Standard_EXPORT ~SMDS_MeshNode(); - - - - - // Type management - // - Standard_EXPORT friend Handle_Standard_Type& SMDS_MeshNode_Type_(); - Standard_EXPORT const Handle(Standard_Type)& DynamicType() const; - Standard_EXPORT Standard_Boolean IsKind(const Handle(Standard_Type)&) const; - -protected: - - // Methods PROTECTED - // - - - // Fields PROTECTED - // - - -private: - - // Methods PRIVATE - // - - - // Fields PRIVATE - // -gp_Pnt myPnt; -SMDS_ListOfMeshElement myInverseElements; -Handle_SMDS_Position myPosition; - - +#include "SMDS_Position.hxx" + +#include +using namespace std; + +class SMDS_MeshNode:public SMDS_MeshElement +{ + + public: + SMDS_MeshNode(double x, double y, double z); + void Print(ostream & OS) const; + double X() const; + double Y() const; + double Z() const; + void AddInverseElement(const SMDS_MeshElement * ME); + void RemoveInverseElement(const SMDS_MeshElement * parent); + void ClearInverseElements(); + bool emptyInverseElements(); + SMDS_Iterator * GetInverseElementIterator() const; + void SetPosition(SMDS_Position * aPos); + SMDS_Position *GetPosition(); + const SMDS_Position *GetPosition() const; + SMDSAbs_ElementType GetType() const; + int NbNodes() const; + void setXYZ(double x, double y, double z); + friend bool operator<(const SMDS_MeshNode& e1, const SMDS_MeshNode& e2); + + protected: + SMDS_Iterator * + elementsIterator(SMDSAbs_ElementType type) const; + + private: + double myX, myY, myZ; + SMDS_Position *myPosition; + set myInverseElements; }; - -#include "SMDS_MeshNode.lxx" - - - -// other inline functions and methods (like "C++: function call" methods) -// - - #endif