X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Document.h;h=9070718b48974151d3b0a4ea2332f65438340f71;hb=7f5d3b6de3d879b6a11389c06a6f183b2fa5a1b2;hp=efc85b2756a317c37849e096aa522b286b0749a2;hpb=c80e8ac643930b858f4f653e2659896ba587b165;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Document.h b/src/ModelAPI/ModelAPI_Document.h index efc85b275..9070718b4 100644 --- a/src/ModelAPI/ModelAPI_Document.h +++ b/src/ModelAPI/ModelAPI_Document.h @@ -11,7 +11,6 @@ #include class ModelAPI_Feature; -class ModelAPI_Iterator; /// Common groups identifiers /// Group of parameters @@ -20,8 +19,8 @@ static const std::string PARAMETERS_GROUP = "Parameters"; static const std::string CONSTRUCTIONS_GROUP = "Construction"; /// Group of parts static const std::string PARTS_GROUP = "Parts"; -/// Group of sketches -static const std::string SKETCHS_GROUP = "Sketchs"; +/// All created fetaures of the document (a history) +static const std::string FEATURES_GROUP = "Features"; /**\class Model_Document * \ingroup DataModel @@ -70,25 +69,25 @@ public: //! \param creates feature and puts it in the document MODELAPI_EXPORT virtual boost::shared_ptr addFeature(std::string theID) = 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; + //! Removes the feature from the document + MODELAPI_EXPORT virtual void removeFeature(boost::shared_ptr theFeature) = 0; - ///! Creates an iterator of the features by the specific groups - MODELAPI_EXPORT virtual boost::shared_ptr featuresIterator( - const std::string theGroup) = 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; ///! 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; - - //! Returns the index of feature in the group (zero based) - MODELAPI_EXPORT virtual int featureIndex(boost::shared_ptr theFeature) = 0; + feature(const std::string& theGroupID, const int theIndex, const bool isOperation = false) = 0; - ///! Returns the vector of groups already added to the document - MODELAPI_EXPORT virtual const std::vector& getGroups() const = 0; + //! Returns the number of features in the group + MODELAPI_EXPORT virtual int size(const std::string& theGroupID) = 0; /// To virtually destroy the fields of successors virtual ~ModelAPI_Document() {} @@ -99,4 +98,9 @@ protected: {} }; + +//! Pointer on document object +typedef boost::shared_ptr DocumentPtr; + + #endif