X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeRefList.h;h=e92f5eae312dc2f6b08dbee10b8e09a91b97cad2;hb=acfb7413a39dd03b70cd8d2847264e083eac2a25;hp=bf6290c07ddf7bc64573b2e0e982b6bbc8df49d2;hpb=b2392a7380b299a0c0687edc26aa58c1223199ff;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeRefList.h b/src/Model/Model_AttributeRefList.h index bf6290c07..e92f5eae3 100644 --- a/src/Model/Model_AttributeRefList.h +++ b/src/Model/Model_AttributeRefList.h @@ -1,36 +1,64 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: Model_AttributeRefList.h // Created: 8 May 2014 // Author: Mikhail PONIKAROV -#ifndef Model_AttributeRefList_HeaderFile -#define Model_AttributeRefList_HeaderFile +#ifndef Model_AttributeRefList_H_ +#define Model_AttributeRefList_H_ #include "Model.h" #include "ModelAPI_AttributeRefList.h" +#include "ModelAPI_Feature.h" + #include /**\class Model_AttributeRefList * \ingroup DataModel * \brief Attribute that contains list of references to features (located in the same document). + * For the current moment it does not support references to objects in other documents. */ class Model_AttributeRefList : public ModelAPI_AttributeRefList { - Handle_TDataStd_ReferenceList myRef; ///< references to the features labels -public: + Handle_TDataStd_ReferenceList myRef; ///< references to the features labels + public: /// Appends the feature to the end of a list - MODEL_EXPORT virtual void append(boost::shared_ptr theFeature); + MODEL_EXPORT virtual void append(ObjectPtr theObject); /// Erases the first meet of the feature in the list - MODEL_EXPORT virtual void remove(boost::shared_ptr theFeature); + MODEL_EXPORT virtual void remove(ObjectPtr theObject); /// Returns number of features in the list - MODEL_EXPORT virtual int size(); + ///\param theWithEmpty if it is false, returns the number of not-empty referenced objects + MODEL_EXPORT virtual int size(const bool theWithEmpty = true) const; + + /// Removes all references from the list + MODEL_EXPORT virtual void clear(); /// Returns the list of features - MODEL_EXPORT virtual std::list > list(); + MODEL_EXPORT virtual std::list list(); + + /// Returns true if the object is in list + MODEL_EXPORT virtual bool isInList(const ObjectPtr& theObj); + + /// Returns the list of features + ///\param theIndex zero-based index in the list + ///\param theWithEmpty if it is false, counts the not-empty referenced objects only + MODEL_EXPORT virtual ObjectPtr object(const int theIndex, const bool theWithEmpty = true) const; + + /// Substitutes the feature by another one. Does nothing if such object is not found. + MODEL_EXPORT virtual void substitute(const ObjectPtr& theCurrent, const ObjectPtr& theNew); + + /// Substitutes the object by another one and back. So, features will become exchanged in the list + MODEL_EXPORT virtual void exchange(const ObjectPtr& theObject1, const ObjectPtr& theObject2); + + /// Removes the last element in the list. + MODEL_EXPORT virtual void removeLast(); -protected: + /// Returns true if attribute was initialized by some value + MODEL_EXPORT virtual bool isInitialized(); + protected: /// Objects are created for features automatically MODEL_EXPORT Model_AttributeRefList(TDF_Label& theLabel);