Salome HOME
Update constraint Tangent to process non-connected features. Improve corresponding...
[modules/shaper.git] / src / ModelAPI / ModelAPI_AttributeSelectionList.h
index 19e888f15f8b9e86016b7aa95830275c2c0da495..c5fe4c9349c007dd198181777c11c846187825ee 100644 (file)
@@ -20,16 +20,40 @@ 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
+  /// Reset temporary stored values
+  virtual void removeTemporaryValues() = 0;
+
+  /// 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<int>& 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<GeomAPI_Shape>& theSubShape,
+    const bool theTemporarily = false) = 0;
+
   /// The type of all elements selection
   /// \returns the index of the enumeration of the type of shape
   virtual const std::string selectionType() const = 0;
@@ -44,8 +68,13 @@ 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 type()
+  static std::string typeId()
   {
     return "SelectionList";
   }