Salome HOME
Issue #2130: arc is done not as desired
[modules/shaper.git] / src / Events / Events_Listener.cpp
index 8a7720c72af788edfb5a3ca4093c69e29ab8d078..e29f3c178875645bbcd90b18242c05bbc566a5d5 100644 (file)
@@ -1,5 +1,37 @@
+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
+
 // File:       Events_Listener.cxx
 // Created:    Thu Mar 13 2014
 // Author:     Mikhail PONIKAROV
 
 #include <Events_Listener.h>
+#include <Events_MessageGroup.h>
+#include <Events_Loop.h>
+
+void Events_Listener::groupWhileFlush(const std::shared_ptr<Events_Message>& theMessage) {
+  std::shared_ptr<Events_MessageGroup> aGroup =
+    std::dynamic_pointer_cast<Events_MessageGroup>(theMessage);
+  if (aGroup) {
+    std::map<char*, std::shared_ptr<Events_Message> >::iterator aMyGroup = myGroups.find(
+      aGroup->eventID().eventText());
+    if (aMyGroup == myGroups.end()) {  // create a new group of messages for accumulation
+      myGroups[aGroup->eventID().eventText()] = aGroup->newEmpty();
+      aMyGroup = myGroups.find(aGroup->eventID().eventText());
+    }
+    std::shared_ptr<Events_MessageGroup> aStored =
+      std::dynamic_pointer_cast<Events_MessageGroup>(aMyGroup->second);
+    aStored->Join(aGroup);
+    //std::cout<<"Add to group "<<theMessage->eventID().eventText()<<std::endl;
+    return;
+  }
+}
+
+void Events_Listener::flushGrouped(const Events_ID& theID) {
+  std::map<char*, std::shared_ptr<Events_Message> >::iterator aMyGroup =
+    myGroups.find(theID.eventText());
+  if (aMyGroup != myGroups.end()) {
+    std::shared_ptr<Events_Message> aMessage = aMyGroup->second;
+    myGroups.erase(aMyGroup);
+    processEvent(aMessage);
+  }
+}