]> SALOME platform Git repositories - modules/shaper.git/blobdiff - src/Model/Model_Events.cpp
Salome HOME
Created a new event that features were reordered due to the "move to end" action
[modules/shaper.git] / src / Model / Model_Events.cpp
index 13c4d256873c97719cc6a525c49006d26432cf13..fb5b650d1e068cfdaa3e22588461e65e9e19ba45 100644 (file)
@@ -27,6 +27,14 @@ void Model_EventCreator::sendDeleted(const std::shared_ptr<ModelAPI_Document>& t
   Events_Loop::loop()->send(aMsg, true);
 }
 
+void Model_EventCreator::sendReordered(const std::shared_ptr<ModelAPI_Document>& theDoc,
+                                       const std::string& theGroup) const
+{
+  std::shared_ptr<Model_OrderUpdatedMessage> aMsg(
+    new Model_OrderUpdatedMessage(theDoc, theGroup));
+  Events_Loop::loop()->send(aMsg, true);
+}
+
 Model_EventCreator::Model_EventCreator()
 {
   ModelAPI_EventCreator::set(this);
@@ -94,3 +102,34 @@ void Model_ObjectDeletedMessage::Join(const std::shared_ptr<Events_MessageGroup>
     myGroups.insert(*aGIter);
   }
 }
+
+/////////////////////// REORDERED MESSAGE /////////////////////////////
+Model_OrderUpdatedMessage::Model_OrderUpdatedMessage(
+    const std::shared_ptr<ModelAPI_Document>& theDoc, const std::string& theGroup)
+    : ModelAPI_OrderUpdatedMessage(messageId(), 0),
+      myDoc(theDoc)
+{
+  if (!theGroup.empty())
+    myGroups.insert(theGroup);
+}
+
+std::shared_ptr<Events_MessageGroup> Model_OrderUpdatedMessage::newEmpty()
+{
+  return std::shared_ptr<Model_OrderUpdatedMessage>(new Model_OrderUpdatedMessage(myDoc, ""));
+}
+
+const Events_ID Model_OrderUpdatedMessage::messageId()
+{
+  static Events_ID MY_ID = Events_Loop::eventByName(EVENT_ORDER_UPDATED);
+  return MY_ID;
+}
+
+void Model_OrderUpdatedMessage::Join(const std::shared_ptr<Events_MessageGroup>& theJoined)
+{
+  std::shared_ptr<Model_OrderUpdatedMessage> aJoined = 
+    std::dynamic_pointer_cast<Model_OrderUpdatedMessage>(theJoined);
+  std::set<std::string>::iterator aGIter = aJoined->myGroups.begin();
+  for (; aGIter != aJoined->myGroups.end(); aGIter++) {
+    myGroups.insert(*aGIter);
+  }
+}