X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeRefList.h;h=3879f31a78dde28a3a9b42237ef5cef2d3bd271f;hb=362b45a781c3209b8363570fe9fee316dfc1928e;hp=1964c7d58d26b945bae3dfbd6a80a6a744b202b7;hpb=a94fc319f2aa64b43c9a73b5ff7063923648faec;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeRefList.h b/src/Model/Model_AttributeRefList.h index 1964c7d58..3879f31a7 100644 --- a/src/Model/Model_AttributeRefList.h +++ b/src/Model/Model_AttributeRefList.h @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// Copyright (C) 2014-2020 CEA/DEN, EDF R&D // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -12,10 +12,9 @@ // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ or -// email : webmaster.salome@opencascade.com +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #ifndef Model_AttributeRefList_H_ @@ -37,11 +36,16 @@ class Model_AttributeRefList : public ModelAPI_AttributeRefList { TDF_Label myLab; ///< the main label of this attribute + 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: + bool myHashUsed; ///< true if the hash stored is valid + std::set myHashObjects; ///< hashed information: objects existing in the list + std::map myHashIndex; ///< index to object in the list + std::map myHashIndexNoEmpty; ///< index to not empty object in the list +public: /// Appends the feature to the end of a list MODEL_EXPORT virtual void append(ObjectPtr theObject); @@ -64,16 +68,12 @@ class Model_AttributeRefList : public ModelAPI_AttributeRefList /// 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; + MODEL_EXPORT virtual ObjectPtr object(const int theIndex, const bool theWithEmpty = true); /// 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(); @@ -85,7 +85,11 @@ class Model_AttributeRefList : public ModelAPI_AttributeRefList /// Returns true if attribute was initialized by some value MODEL_EXPORT virtual bool isInitialized(); - protected: + + /// Erases the hashed objects caused by complicated modifications in the list + void eraseHash(); + +protected: /// Objects are created for features automatically MODEL_EXPORT Model_AttributeRefList(TDF_Label& theLabel); /// Reinitializes the internal state of the attribute (may be needed on undo/redo, abort, etc) @@ -94,6 +98,8 @@ class Model_AttributeRefList : public ModelAPI_AttributeRefList ObjectPtr iteratedObject(TDF_ListIteratorOfLabelList& theLIter, TDataStd_ListIteratorOfListOfExtendedString& theExtIter, std::shared_ptr theDoc) const; + /// Creates the hash-objects containers (does nothing if hash is already correct) + void createHash(); friend class Model_Data; };