X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Feventmanager.h;h=a41dbe5d490cc090b5cabf452324503e2d0c6e85;hp=b19e8eeeb4cb25891a7c9a64b5254d35e87add72;hb=46984aca05b2d5f8dddd0c8739e60a1753078123;hpb=03b1230e44adca6b808a6a702aa5173e578a1160 diff --git a/src/common/eventmanager.h b/src/common/eventmanager.h index b19e8eee..a41dbe5d 100644 --- a/src/common/eventmanager.h +++ b/src/common/eventmanager.h @@ -21,13 +21,13 @@ #ifndef EVENTMANAGER_H #define EVENTMANAGER_H -#include -#include +#include class Event; class EventManager : public QObject { Q_OBJECT + Q_FLAGS(EventFlag EventFlags) Q_ENUMS(EventType) public: @@ -45,6 +45,12 @@ public: HighestPriority }; + enum EventFlag { + Backlog = 0x40, + Stopped = 0x80 + }; + Q_DECLARE_FLAGS(EventFlags, EventFlag) + /* */ @@ -68,10 +74,11 @@ public: IrcServerEvent = 0x00020000, IrcServerIncoming, + IrcServerParseError, IrcEvent = 0x00030000, + IrcEventAuthenticate, IrcEventCap, - IrcEventCapAuthenticate, IrcEventInvite, IrcEventJoin, IrcEventKick, @@ -84,19 +91,34 @@ public: IrcEventPrivmsg, IrcEventQuit, IrcEventTopic, + IrcEventRawPrivmsg, ///< Undecoded privmsg (still needs CTCP parsing) + IrcEventRawNotice, ///< Undecoded notice (still needs CTCP parsing) + IrcEventUnknown, ///< Unknown non-numeric cmd IrcEventNumeric = 0x00031000, /* needs 1000 (0x03e8) consecutive free values! */ + IrcEventNumericMask = 0x00000fff, /* for checking if an event is numeric */ + + MessageEvent = 0x00040000, ///< Stringified event suitable for converting to Message }; EventManager(QObject *parent = 0); - //virtual ~EventManager(); + virtual ~EventManager(); - QStringList providesEnums(); + EventType eventTypeByName(const QString &name) const; + EventType eventGroupByName(const QString &name) const; + QString enumName(EventType type) const; public slots: - void registerObject(QObject *object, Priority priority = NormalPriority, const QString &methodPrefix = "handle"); - void registerEventHandler(EventType event, QObject *object, const char *slot, Priority priority = NormalPriority); - void registerEventHandler(QList events, QObject *object, const char *slot, Priority priority = NormalPriority); + void registerObject(QObject *object, Priority priority = NormalPriority, + const QString &methodPrefix = "process", + const QString &filterPrefix = "filter"); + void registerEventHandler(EventType event, QObject *object, const char *slot, + Priority priority = NormalPriority, bool isFilter = false); + void registerEventHandler(QList events, QObject *object, const char *slot, + Priority priority = NormalPriority, bool isFilter = false); + + void registerEventFilter(EventType event, QObject *object, const char *slot); + void registerEventFilter(QList events, QObject *object, const char *slot); //! Send an event to the registered handlers /** @@ -106,6 +128,9 @@ public slots: */ void sendEvent(Event *event); +protected: + virtual void customEvent(QEvent *event); + private: struct Handler { QObject *object; @@ -124,13 +149,29 @@ private: inline const HandlerHash ®isteredHandlers() const { return _registeredHandlers; } inline HandlerHash ®isteredHandlers() { return _registeredHandlers; } + inline const HandlerHash ®isteredFilters() const { return _registeredFilters; } + inline HandlerHash ®isteredFilters() { return _registeredFilters; } + //! Add handlers to an existing sorted (by priority) handler list void insertHandlers(const QList &newHandlers, QList &existing); + //! 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 dispatchEvent(Event *event); + //! @return the EventType enum + QMetaEnum eventEnum() const; + HandlerHash _registeredHandlers; + HandlerHash _registeredFilters; + mutable QMetaEnum _enum; + QList _eventQueue; }; +Q_DECLARE_OPERATORS_FOR_FLAGS(EventManager::EventFlags); + #endif