X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Feventmanager.h;h=e01b594d990ecd0bbec3fc7e6e0b1057b3d1ca03;hp=4030cffa7760370ae8cd808ad74d0eb85a1a8567;hb=a72e2b4a90ce18c58b54e111161691ba008dc47d;hpb=46a76ffbf0e9e7af3d4ceb074c0b8dff461b4a86 diff --git a/src/common/eventmanager.h b/src/common/eventmanager.h index 4030cffa..e01b594d 100644 --- a/src/common/eventmanager.h +++ b/src/common/eventmanager.h @@ -46,11 +46,14 @@ public: }; enum EventFlag { - Backlog = 0x20, - Silent = 0x40, ///< Don't generate a MessageEvent - Stopped = 0x80 + Self = 0x01, ///< Self-generated (user input) event + Fake = 0x08, ///< Ignore this in CoreSessionEventProcessor + Netsplit = 0x10, ///< Netsplit join/part, ignore on display + Backlog = 0x20, + Silent = 0x40, ///< Don't generate a MessageEvent + Stopped = 0x80 }; - Q_DECLARE_FLAGS(EventFlags, EventFlag) + Q_DECLARE_FLAGS(EventFlags, EventFlag); /* @@ -71,6 +74,8 @@ public: NetworkReconnecting, NetworkDisconnecting, NetworkDisconnected, + NetworkSplitJoin, + NetworkSplitQuit, NetworkIncoming, IrcServerEvent = 0x00020000, @@ -100,13 +105,16 @@ public: IrcEventNumericMask = 0x00000fff, /* for checking if an event is numeric */ MessageEvent = 0x00040000, ///< Stringified event suitable for converting to Message + + CtcpEvent = 0x00050000, + CtcpEventFlush, }; EventManager(QObject *parent = 0); - virtual ~EventManager(); EventType eventTypeByName(const QString &name) const; EventType eventGroupByName(const QString &name) const; + QString enumName(EventType type) const; public slots: @@ -124,10 +132,9 @@ public slots: //! Send an event to the registered handlers /** The EventManager takes ownership of the event and will delete it once it's processed. - NOTE: This method is not threadsafe! @param event The event to be dispatched */ - void sendEvent(Event *event); + void postEvent(Event *event); protected: virtual void customEvent(QEvent *event); @@ -154,13 +161,13 @@ private: inline HandlerHash ®isteredFilters() { return _registeredFilters; } //! Add handlers to an existing sorted (by priority) handler list - void insertHandlers(const QList &newHandlers, QList &existing); + void insertHandlers(const QList &newHandlers, QList &existing, bool checkDupes = false); //! Add filters to an existing filter hash void insertFilters(const QList &newFilters, QHash &existing); int findEventType(const QString &methodSignature, const QString &methodPrefix) const; - void processEvents(); + void processEvent(Event *event); void dispatchEvent(Event *event); //! @return the EventType enum @@ -169,7 +176,6 @@ private: HandlerHash _registeredHandlers; HandlerHash _registeredFilters; mutable QMetaEnum _enum; - QList _eventQueue; };