X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FEvents%2FEvents_Loop.h;h=f53307c5bfd57a6675dd30e91cc74f7184e13ff7;hb=0748a19e5641e488fb258ac14620d7bd66331ce0;hp=c8b7798c0e06944cdc3348fdbe6e60126a662ee1;hpb=4783f146b71a48c651523fcf0e12367bcf3d1fa8;p=modules%2Fshaper.git diff --git a/src/Events/Events_Loop.h b/src/Events/Events_Loop.h index c8b7798c0..f53307c5b 100644 --- a/src/Events/Events_Loop.h +++ b/src/Events/Events_Loop.h @@ -1,6 +1,22 @@ -// File: Events_Loop.hxx -// Created: Thu Mar 13 2014 -// Author: Mikhail PONIKAROV +// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// +// This library is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 2.1 of the License, or (at your option) any later version. +// +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or +// email : webmaster.salome@opencascade.com +// #ifndef Events_Loop_H_ #define Events_Loop_H_ @@ -14,7 +30,7 @@ class Events_MessageGroup; -/**\class Events_Lopp +/**\class Events_Loop * \ingroup EventsLoop * \brief Base class that manages the receiving and sending of all * not Qt-events in the application. @@ -32,7 +48,7 @@ class Events_Loop /// 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) + /// map from event ID to groupped messages (accumulated for flush) std::map > myGroups; ///< set of messages that are flushed right now, so they are not grouped @@ -52,26 +68,52 @@ class Events_Loop EVENTS_EXPORT static Events_ID eventByName(const char* theName); //! Allows to send an event + //! \param theMessage the enevt message to send //! \param isGroup is true for grouping messages if possible EVENTS_EXPORT void send(const std::shared_ptr& theMessage, bool isGroup = true); - //! Registers (or adds if such listener is already registered) a listener + //! Registers (or adds if such listener is already registered) a listener //! that will be called on the event and from the defined sender + //! \param theListener the object that will listen (process) the event + //! \param theID listen for messages with this ID + //! \param theSender listen only for this sender (NULL - listen everybody) + //! \param theImmediate for listeners who can not wait (no groupping mechanism is used for it) EVENTS_EXPORT void registerListener(Events_Listener* theListener, const Events_ID theID, - void* theSender = 0, bool theImmediate = false); + void* theSender = 0, bool theImmediate = false); + + //! Remove the listener from internal maps if it was registered there + //! \param theListener a listener + EVENTS_EXPORT void removeListener(Events_Listener* theListener); //! Initializes sending of a group-message by the given ID EVENTS_EXPORT void flush(const Events_ID& theID); - //! Allows to disable flushes: needed in synchronization of document mechanism + //! Removes messages with the given ID: they are not needed anymore (UPDATE on close) + EVENTS_EXPORT void eraseMessages(const Events_ID& theID); + + //! 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); + //! \param theActivate a state about flushe is active. If false, the flush is disabled + //! \return the previous active flush state + EVENTS_EXPORT bool 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); + + //! Returns true if a loop accumulated events to be flashed + EVENTS_EXPORT bool hasGrouppedEvent(const Events_ID& theID); + +private: + //! Calls "processEvent" for the given listeners. + //! If theFlushedNow for grouped listeners is stores message in listeners. + void sendProcessEvent(const std::shared_ptr& theMessage, + std::list& theListeners, const bool theFlushedNow); + }; #endif