X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModel%2FModel_AttributeSelectionList.h;h=0caf621b18c0f8cabc9c61816110723b878ed259;hb=41f9517e84ae934ce536718d4f48e26731c8430d;hp=6721dd8adfff67a59d0ed9b1a458a1de8bfe6fc8;hpb=bad8dbf3aac92f2f845f4a4d397a06be7458a60b;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeSelectionList.h b/src/Model/Model_AttributeSelectionList.h index 6721dd8ad..0caf621b1 100644 --- a/src/Model/Model_AttributeSelectionList.h +++ b/src/Model/Model_AttributeSelectionList.h @@ -13,6 +13,7 @@ #include #include #include +#include /**\class Model_AttributeSelectionList * \ingroup DataModel @@ -22,9 +23,14 @@ class Model_AttributeSelectionList : public ModelAPI_AttributeSelectionList { + TDF_Label myLab; ///< the main label of this attribute Handle(TDataStd_Integer) mySize; ///< Contains size of this list - Handle(TDataStd_Comment) mySelectionType; ///< Contains current type name (same as selection attribute) + /// Contains current type name (same as selection attribute) + Handle(TDataStd_Comment) mySelectionType; std::shared_ptr myTmpAttr; ///< temporary attribute (the last one) + /// the cashed shapes to optimize isInList method: from context to set of shapes in this context + std::map > > myCash; + bool myIsCashed; ///< true if cashing is performed public: /// Adds the new reference to the end of the list /// \param theContext object where the sub-shape was selected @@ -39,12 +45,28 @@ public: /// The type of shape is taken from the current selection type if the given is empty MODEL_EXPORT virtual void append(const std::string theNamingName, const std::string& theType=""); + /// Reset temporary stored values + virtual void removeTemporaryValues(); + /// Removes the last element in the list MODEL_EXPORT virtual void removeLast(); + /// Removes the elements from the list. + /// \param theIndices a list of indices of elements to be removed + MODEL_EXPORT virtual void remove(const std::set& theIndices); + /// Returns the number ofselection attributes in the list MODEL_EXPORT virtual int size(); + /// Returns true if the object with the shape are in list + /// \param theContext object where the sub-shape was selected + /// \param theSubShape selected sub-shape (if null, the whole context is selected) + /// \param theTemporarily if it is true, it checks also the temporary added item + /// \returns true if the pair is found in the attirbute + MODEL_EXPORT virtual bool isInList( + const ResultPtr& theContext, const std::shared_ptr& theSubShape, + const bool theTemporarily = false); + /// The type of all elements selection /// \returns the index of the OCCT enumeration of the type of shape MODEL_EXPORT virtual const std::string selectionType() const; @@ -62,9 +84,16 @@ public: /// Returns true if attribute was initialized by some value MODEL_EXPORT virtual bool isInitialized(); + /// Starts or stops cashing of the values in the attribute (the cash may become invalid + /// on modification of the attribute or sub-elements, so the cash must be enabled only + /// during non-modification operations with this attribute) + MODEL_EXPORT virtual void cashValues(const bool theEnabled); + protected: /// Objects are created for features automatically MODEL_EXPORT Model_AttributeSelectionList(TDF_Label& theLabel); + /// Reinitializes the internal state of the attribute (may be needed on undo/redo, abort, etc) + virtual void reinit(); friend class Model_Data; };