X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Fsignalproxy.h;h=1a8dfac96dfa3248cacf4acd152adb296c96db31;hb=4b41d8800c38aa3bc4e88a76289b45bc888ba088;hp=bf3742dbc630d733fba211cdd87be825577ddc92;hpb=53fb39baea40512c3b88abcf37a14cef05fcc287;p=quassel.git diff --git a/src/common/signalproxy.h b/src/common/signalproxy.h index bf3742db..1a8dfac9 100644 --- a/src/common/signalproxy.h +++ b/src/common/signalproxy.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-07 by the Quassel IRC Team * + * Copyright (C) 2005-08 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -32,6 +32,7 @@ #include class SignalRelay; +class SyncableObject; class QMetaObject; class SignalProxy : public QObject { @@ -63,18 +64,16 @@ public: bool attachSignal(QObject *sender, const char *signal, const QByteArray& sigName = QByteArray()); bool attachSlot(const QByteArray& sigName, QObject *recv, const char *slot); - void synchronize(QObject *obj); - void synchronizeAsMaster(QObject *obj); - void synchronizeAsSlave(QObject *obj); + void synchronize(SyncableObject *obj); - void setInitialized(QObject *obj); - bool initialized(QObject *obj); - void requestInit(QObject *obj); + void setInitialized(SyncableObject *obj); + bool initialized(SyncableObject *obj); + void requestInit(SyncableObject *obj); void detachObject(QObject *obj); void detachSignals(QObject *sender); void detachSlots(QObject *receiver); - void stopSync(QObject *obj); + void stopSync(SyncableObject *obj); //! Writes a QVariant to a device. /** The data item is prefixed with the resulting blocksize, @@ -92,8 +91,9 @@ public: static QString methodBaseName(const QMetaMethod &method); const QList &argTypes(QObject *obj, int methodId); + bool hasUpdateSignal(QObject *obj); const QByteArray &methodName(QObject *obj, int methodId); - const QHash &syncMap(QObject *obj); + const QHash &syncMap(SyncableObject *obj); typedef QHash > ArgHash; typedef QHash MethodNameHash; @@ -101,6 +101,7 @@ public: ArgHash argTypes; MethodNameHash methodNames; QHash syncMap; + bool hasUpdateSignal; }; void dumpProxyStats(); @@ -124,7 +125,7 @@ private: void createClassInfo(QObject *obj); void setArgTypes(QObject *obj, int methodId); void setMethodName(QObject *obj, int methodId); - void setSyncMap(QObject *obj); + void setSyncMap(SyncableObject *obj); bool methodsMatch(const QMetaMethod &signal, const QMetaMethod &slot) const; @@ -139,16 +140,15 @@ private: bool invokeSlot(QObject *receiver, int methodId, const QVariantList ¶ms); - QVariantMap initData(QObject *obj) const; - void setInitData(QObject *obj, const QVariantMap &properties); - bool setInitValue(QObject *obj, const QString &property, const QVariant &value); + QVariantMap initData(SyncableObject *obj) const; + void setInitData(SyncableObject *obj, const QVariantMap &properties); void _detachSignals(QObject *sender); void _detachSlots(QObject *receiver); - void _stopSync(QObject *obj); + void _stopSync(SyncableObject *obj); + + void dumpSyncMap(SyncableObject *object); - void dumpSyncMap(QObject *object); - // Hash of used QIODevices QHash _peerByteCount; @@ -164,7 +164,7 @@ private: SlotHash _attachedSlots; // slaves for sync - typedef QHash ObjectId; + typedef QHash ObjectId; QHash _syncSlave;