X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Feventmanager.h;h=7ead8ba198ab4eda231ba131ffa0dcf5f17b0fdd;hp=698b37460db59502fce7f02bb8799a22f06b08da;hb=3456106b07bfc3000e50df9322ddefd4f872e0fb;hpb=eca32e09b23dd261d7eaf11a4843949220b302d4 diff --git a/src/common/eventmanager.h b/src/common/eventmanager.h index 698b3746..7ead8ba1 100644 --- a/src/common/eventmanager.h +++ b/src/common/eventmanager.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2010 by the Quassel Project * + * Copyright (C) 2005-2012 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -46,10 +46,14 @@ public: }; enum EventFlag { - Backlog = 0x40, - 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); /* @@ -70,6 +74,8 @@ public: NetworkReconnecting, NetworkDisconnecting, NetworkDisconnected, + NetworkSplitJoin, + NetworkSplitQuit, NetworkIncoming, IrcServerEvent = 0x00020000, @@ -77,8 +83,8 @@ public: IrcServerParseError, IrcEvent = 0x00030000, + IrcEventAuthenticate, IrcEventCap, - IrcEventCapAuthenticate, IrcEventInvite, IrcEventJoin, IrcEventKick, @@ -96,29 +102,39 @@ public: 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 + + 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; + static EventType eventTypeByName(const QString &name); + static EventType eventGroupByName(const QString &name); + static QString enumName(EventType type); + static QString enumName(int type); // for sanity tests 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 /** 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); @@ -141,19 +157,26 @@ 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); + void insertHandlers(const QList &newHandlers, QList &existing, bool checkDupes = false); + //! Add filters to an existing filter hash + void insertFilters(const QList &newFilters, QHash &existing); - void processEvents(); + int findEventType(const QString &methodSignature, const QString &methodPrefix) const; + + void processEvent(Event *event); void dispatchEvent(Event *event); //! @return the EventType enum - QMetaEnum eventEnum() const; + static QMetaEnum eventEnum(); HandlerHash _registeredHandlers; - mutable QMetaEnum _enum; - + HandlerHash _registeredFilters; QList _eventQueue; + static QMetaEnum _enum; }; Q_DECLARE_OPERATORS_FOR_FLAGS(EventManager::EventFlags);