X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FEvents%2FEvents_Loop.h;h=669c56febbc72e3acf676608a38acb6643112ad5;hb=f15b088eb4ce09ba9740bd614398c8048916a17c;hp=cd78497ed1c67b0c7b3482d5964df9b49674572b;hpb=deb0185764c5a7ab524646cfdc2b7ce22afae81d;p=modules%2Fshaper.git diff --git a/src/Events/Events_Loop.h b/src/Events/Events_Loop.h index cd78497ed..669c56feb 100644 --- a/src/Events/Events_Loop.h +++ b/src/Events/Events_Loop.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: Events_Loop.hxx // Created: Thu Mar 13 2014 // Author: Mikhail PONIKAROV @@ -9,6 +11,7 @@ #include #include +#include #include class Events_MessageGroup; @@ -28,8 +31,14 @@ class Events_Loop /// map from event ID to sender pointer to listeners that must be called for this std::map > > myListeners; + /// map from event ID to listeners which must process message without waiting for flush + std::map myImmediateListeners; + /// map from event ID to groupped messages (accumulated on flush) - std::map myGroups; + std::map > myGroups; + + ///< set of messages that are flushed right now, so they are not grouped + std::set myFlushed; /// to process flushes or not bool myFlushActive; @@ -46,12 +55,12 @@ class Events_Loop //! Allows to send an event //! \param isGroup is true for grouping messages if possible - EVENTS_EXPORT void send(Events_Message& theMessage, bool isGroup = true); + EVENTS_EXPORT void send(const std::shared_ptr& theMessage, bool isGroup = true); //! Registers (or adds if such listener is already registered) a listener //! that will be called on the event and from the defined sender EVENTS_EXPORT void registerListener(Events_Listener* theListener, const Events_ID theID, - void* theSender = 0); + void* theSender = 0, bool theImmediate = false); //! Initializes sending of a group-message by the given ID EVENTS_EXPORT void flush(const Events_ID& theID); @@ -59,6 +68,17 @@ class Events_Loop //! Allows to disable flushes: needed in synchronization of document mechanism //! (to synchronize all and only then flush create, update, etc in correct order) EVENTS_EXPORT void activateFlushes(const bool theActivate); + + //! Clears all collected messages + EVENTS_EXPORT void clear(const Events_ID& theID); + + //! Enables flush without grouping for the given message + EVENTS_EXPORT void autoFlush(const Events_ID& theID, const bool theAuto = true); + + //! Returns true if the evement is flushed right now + EVENTS_EXPORT bool isFlushed(const Events_ID& theID); + //! Sets the flag that the event is flished right now + EVENTS_EXPORT void setFlushed(const Events_ID& theID, const bool theValue); }; #endif