X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FSMDS%2FSMDS_Position.hxx;h=ea8591706c9fffc4cbfa5ab63f2784a36aa733ed;hp=3d9dbf53e7fa73353d82c20a756f85f8f3fc8fac;hb=d9f4b53e489dd5857db264ede6acded7b076c9f1;hpb=7eda9ca931ed2a11cb5e4637e4ffe19f5c061115 diff --git a/src/SMDS/SMDS_Position.hxx b/src/SMDS/SMDS_Position.hxx index 3d9dbf53e..ea8591706 100644 --- a/src/SMDS/SMDS_Position.hxx +++ b/src/SMDS/SMDS_Position.hxx @@ -1,4 +1,4 @@ -// Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE +// Copyright (C) 2007-2022 CEA/DEN, EDF R&D, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS @@ -20,7 +20,7 @@ // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // -// SMESH SMDS : implementaion of Salome mesh data structure +// SMESH SMDS : implementation of Salome mesh data structure // File : SMDS_Position.hxx // Module : SMESH // @@ -30,23 +30,68 @@ #include "SMESH_SMDS.hxx" #include "SMDS_TypeOfPosition.hxx" -#include +#include -class SMDS_Position; +//class SMDS_Position; //typedef boost::shared_ptr SMDS_PositionPtr; -typedef SMDS_Position* SMDS_PositionPtr; +//typedef SMDS_Position* SMDS_PositionPtr; class SMDS_EXPORT SMDS_Position { - public: - virtual SMDS_TypeOfPosition GetTypeOfPosition() const = 0; - virtual int GetDim() const; - virtual ~SMDS_Position() {} + public: + virtual SMDS_TypeOfPosition GetTypeOfPosition() const = 0; + int GetDim() const { return GetTypeOfPosition(); } + virtual const double* GetParameters() const = 0; + virtual ~SMDS_Position() {} +}; + +/*! + * \brief Replace "typedef SMDS_Position* SMDS_PositionPtr" by a smart + * pointer allowing implicit casting to derived types; e.g. + * if ( SMDS_FacePositionPtr fPos = node->GetPosition() ) + * fPos->SetUParameter(0); + */ + +template +class SMDS_Ptr : public std::unique_ptr< T > +{ + bool myIsOwner; + + public: + SMDS_Ptr( T * pos = (T *) 0, bool isOwner=true ): + std::unique_ptr< T >( pos ), myIsOwner( isOwner ) {} + + SMDS_Ptr( const SMDS_Ptr& from ) : std::unique_ptr< T >(), myIsOwner( from.myIsOwner ) + { this->swap( const_cast( from )); } + + SMDS_Ptr& operator=( const SMDS_Ptr& from ) + { + myIsOwner = from.myIsOwner; + this->swap( const_cast( from )); + return *this; + } + + template + SMDS_Ptr( const SMDS_Ptr< Y >& base ): myIsOwner( true ) + { + if ( const T* p = dynamic_cast( base.get() )) + { + this->reset( const_cast( p )); + this->myIsOwner = base.IsOwner(); + const_cast< SMDS_Ptr< Y >& >( base ).release(); + } + } + ~SMDS_Ptr() { if ( !myIsOwner ) this->release(); } - protected: - SMDS_Position(); + operator bool () const { return bool( this->get() ); } + bool IsOwner() const { return myIsOwner; } }; +class SMDS_EdgePosition; +class SMDS_FacePosition; +typedef SMDS_Ptr< SMDS_Position > SMDS_PositionPtr; +typedef SMDS_Ptr< SMDS_EdgePosition > SMDS_EdgePositionPtr; +typedef SMDS_Ptr< SMDS_FacePosition > SMDS_FacePositionPtr; #endif