X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeRefList.h;h=b3690b2272466bff7c8fb6683f3a893524ceeba5;hb=45400ecc7d183dd2d2edb875bdb36f8fc031bc2c;hp=87525753e1cab74ef7dba352a2fcdedc1937a280;hpb=2c4f7de06341fa7af89f47ba405fe188f13e3600;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeRefList.h b/src/Model/Model_AttributeRefList.h index 87525753e..b3690b227 100644 --- a/src/Model/Model_AttributeRefList.h +++ b/src/Model/Model_AttributeRefList.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: Model_AttributeRefList.h // Created: 8 May 2014 // Author: Mikhail PONIKAROV @@ -8,18 +10,23 @@ #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 -public: + 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); @@ -27,14 +34,49 @@ public: 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(); + + /// Returns true if the object is in list + MODEL_EXPORT virtual bool isInList(const ObjectPtr& theObj); /// Returns the list of features - MODEL_EXPORT virtual std::list list(); + ///\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); -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); + /// 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; };