X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FSMDS%2FSMDS_Position.hxx;h=62c4042d3322fd09c299aa3afd83d3112b4408c7;hp=b6976677d291a5ae3f9d6f5f3e5c875cd23158d0;hb=4c16067d4281f56bd07d3f92fb63fff9c0c1d169;hpb=7a713be33b27d6a8c77f983460f0e97e52c6ff7c diff --git a/src/SMDS/SMDS_Position.hxx b/src/SMDS/SMDS_Position.hxx index b6976677d..62c4042d3 100644 --- a/src/SMDS/SMDS_Position.hxx +++ b/src/SMDS/SMDS_Position.hxx @@ -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_EXPORT 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 ) : 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