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=a91b55923d025df8b971eced4969a2d477c01ec9;hb=d9f4b53e489dd5857db264ede6acded7b076c9f1;hpb=bd8f1aee7c78f7d2eb82bd4fec5e08c9e3d280ce diff --git a/src/SMDS/SMDS_Position.hxx b/src/SMDS/SMDS_Position.hxx index a91b55923..ea8591706 100644 --- a/src/SMDS/SMDS_Position.hxx +++ b/src/SMDS/SMDS_Position.hxx @@ -1,4 +1,4 @@ -// Copyright (C) 2007-2013 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 @@ -6,7 +6,7 @@ // 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. +// version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -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