X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeRefList.h;h=9f3df94af22df3f9d744041a7f69ae4b1701b082;hb=353cb0b3156491b5985a504f65a6953af2c151b0;hp=2a4550a80bfd376c3437b5c5aaadfc2e82967863;hpb=7bf19255421b34594c7b0a76d0ce28166d0ce895;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeRefList.h b/src/Model/Model_AttributeRefList.h index 2a4550a80..9f3df94af 100644 --- a/src/Model/Model_AttributeRefList.h +++ b/src/Model/Model_AttributeRefList.h @@ -12,15 +12,19 @@ #include "ModelAPI_Feature.h" #include +#include /**\class Model_AttributeRefList * \ingroup DataModel - * \brief Attribute that contains list of references to features (located in the same document). + * \brief Attribute that contains list of references to features, may be located in different documents. */ class Model_AttributeRefList : public ModelAPI_AttributeRefList { Handle_TDataStd_ReferenceList myRef; ///< references to the features labels + /// pairs of doc ID and entries if reference is to external object, appends some in this list if + /// something in myRef is empty + Handle_TDataStd_ExtStringList myExtDocRef; public: /// Appends the feature to the end of a list MODEL_EXPORT virtual void append(ObjectPtr theObject); @@ -29,17 +33,49 @@ class Model_AttributeRefList : public ModelAPI_AttributeRefList MODEL_EXPORT virtual void remove(ObjectPtr theObject); /// Returns number of features in the list - MODEL_EXPORT virtual int size() const; + ///\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(); + /// Returns true if the object is in list + MODEL_EXPORT virtual bool isInList(const ObjectPtr& theObj); + /// Returns the list of features - MODEL_EXPORT virtual ObjectPtr object(const int theIndex) const; + ///\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. + /// Does not support the external documents objects yet. + 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 + /// Does not support the external documents objects yet. + MODEL_EXPORT virtual void exchange(const ObjectPtr& theObject1, const ObjectPtr& theObject2); + + /// Removes the last element in the list. + /// Does not support the external documents objects yet. + MODEL_EXPORT virtual void removeLast(); + + /// Removes the elements from the list. + /// Does not support the external documents objects yet. + /// \param theIndices a list of indices of elements to be removed + MODEL_EXPORT virtual void remove(const std::set& theIndices); + /// 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); + /// Returns the object by iterators (theExtIter is iterated if necessary) + ObjectPtr iteratedObject(TDF_ListIteratorOfLabelList& theLIter, + TDataStd_ListIteratorOfListOfExtendedString& theExtIter, + std::shared_ptr theDoc) const; friend class Model_Data; };