X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Document.h;h=9070718b48974151d3b0a4ea2332f65438340f71;hb=7f5d3b6de3d879b6a11389c06a6f183b2fa5a1b2;hp=4ae7380227ed57209753cbf3c8857670cee363c2;hpb=c52423b158d7e2bae396c62e4fe62e7e8f78c381;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Document.h b/src/ModelAPI/ModelAPI_Document.h index 4ae738022..9070718b4 100644 --- a/src/ModelAPI/ModelAPI_Document.h +++ b/src/ModelAPI/ModelAPI_Document.h @@ -69,25 +69,26 @@ public: //! \param creates feature and puts it in the document MODELAPI_EXPORT virtual boost::shared_ptr addFeature(std::string theID) = 0; + //! Removes the feature from the document + MODELAPI_EXPORT virtual void removeFeature(boost::shared_ptr theFeature) = 0; + ///! Adds a new sub-document by the identifier, or returns existing one if it is already exist - MODELAPI_EXPORT virtual boost::shared_ptr subDocument(std::string theDocID) = 0; + MODELAPI_EXPORT virtual boost::shared_ptr + subDocument(std::string theDocID) = 0; ///! Returns the id of hte document MODELAPI_EXPORT virtual const std::string& id() const = 0; //! Returns the feature in the group by the index (started from zero) + //! \param theGroupID group that contains a feature + //! \param theIndex zero-based index of feature in the group + //! \param isOperation if it is true, returns feature (not Object) MODELAPI_EXPORT virtual boost::shared_ptr - feature(const std::string& theGroupID, const int theIndex) = 0; + feature(const std::string& theGroupID, const int theIndex, const bool isOperation = false) = 0; //! Returns the number of features in the group MODELAPI_EXPORT virtual int size(const std::string& theGroupID) = 0; - //! Returns the index of feature in the group (zero based) - MODELAPI_EXPORT virtual int featureIndex(boost::shared_ptr theFeature) = 0; - - ///! Returns the vector of groups already added to the document - MODELAPI_EXPORT virtual const std::vector& getGroups() const = 0; - /// To virtually destroy the fields of successors virtual ~ModelAPI_Document() {} @@ -97,4 +98,9 @@ protected: {} }; + +//! Pointer on document object +typedef boost::shared_ptr DocumentPtr; + + #endif