X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeRefList.h;h=b3690b2272466bff7c8fb6683f3a893524ceeba5;hb=45400ecc7d183dd2d2edb875bdb36f8fc031bc2c;hp=f59229a1a697f73b231f78e6de162ad8b4a7a334;hpb=6bb3ec6c114b55c02bad00ec953cd5b867eb7083;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeRefList.h b/src/Model/Model_AttributeRefList.h index f59229a1a..b3690b227 100644 --- a/src/Model/Model_AttributeRefList.h +++ b/src/Model/Model_AttributeRefList.h @@ -10,17 +10,22 @@ #include "Model.h" #include "ModelAPI_AttributeRefList.h" #include "ModelAPI_Feature.h" +#include "Model_Document.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,19 +34,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; };