X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_AttributeSelectionList.h;h=aa2e7291574ae0eda5d55c77f5fcbff109a92d59;hb=eff356718b41364a03e808e5a6c790ac718a572d;hp=f440dcb92dcc65bcc7647407b553e274bb8709a0;hpb=8babac25037f2666dcb422dd68a66dd2ed1383d8;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_AttributeSelectionList.h b/src/ModelAPI/ModelAPI_AttributeSelectionList.h index f440dcb92..aa2e72915 100644 --- a/src/ModelAPI/ModelAPI_AttributeSelectionList.h +++ b/src/ModelAPI/ModelAPI_AttributeSelectionList.h @@ -20,23 +20,44 @@ class ModelAPI_AttributeSelectionList : public ModelAPI_Attribute { public: /// Adds the new reference to the end of the 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, do not store and name the added in the data framework + /// (used to remove immediately, without the following updates) virtual void append(const ResultPtr& theContext, - const GeomShapePtr& theSubShape) = 0; + const GeomShapePtr& theSubShape, + const bool theTemporarily = false) = 0; /// Adds the new reference to the end of the list by the naming name of the selected shape - /// The type of shape is taken from the current selection type - virtual void append(std::string theNamingName) = 0; + /// The type of shape is taken from the current selection type if the given is empty + virtual void append(const std::string theNamingName, const std::string& theType = "") = 0; - /// Returns the number ofselection attributes in the list + /// Removes the last element in the list + virtual void removeLast() = 0; + + /// Removes the elements from the list. + /// \param theIndices a list of indices of elements to be removed + virtual void remove(const std::set& theIndices) = 0; + + /// Returns the number of selection attributes in the list virtual int size() = 0; + /// 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 + virtual bool isInList( + const ResultPtr& theContext, const std::shared_ptr& theSubShape, + const bool theTemporarily = false) = 0; + /// The type of all elements selection /// \returns the index of the enumeration of the type of shape - virtual int selectionType() = 0; + virtual const std::string selectionType() const = 0; /// Sets the type of all elements selection /// \param theType the index of the enumeration of the type of shape - virtual void setSelectionType(int theType) = 0; + virtual void setSelectionType(const std::string& theType) = 0; /// Returns the attribute selection by the index (zero based) virtual std::shared_ptr value(const int theIndex) = 0; @@ -44,6 +65,11 @@ class ModelAPI_AttributeSelectionList : public ModelAPI_Attribute /// Returns all attributes virtual void clear() = 0; + /// 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) + virtual void cashValues(const bool theEnabled) = 0; + /// Returns the type of this class of attributes static std::string typeId() {