From 17a902604b2631d1165fb8c7af65e064e37a49d7 Mon Sep 17 00:00:00 2001 From: Marcus Eggenberger Date: Sat, 5 Jan 2008 15:59:12 +0000 Subject: [PATCH 1/1] Added some featues to the SignalProxy. Now SyncSlaves can request that objects residing objects do actions with coresponding requestFoo // fooRequested signal/slot pairs --- src/common/signalproxy.cpp | 60 +++++++++++++++++++++----------------- src/common/signalproxy.h | 2 -- 2 files changed, 33 insertions(+), 29 deletions(-) diff --git a/src/common/signalproxy.cpp b/src/common/signalproxy.cpp index 841a79f8..0af4fdc0 100644 --- a/src/common/signalproxy.cpp +++ b/src/common/signalproxy.cpp @@ -51,6 +51,8 @@ public: int sigCount() const; private: + bool isSyncMethod(int i); + SignalProxy* proxy; QObject* caller; QMultiHash sigNames; @@ -108,19 +110,33 @@ void SignalRelay::setSynchronize(bool sync) { if(!_sync && sync) { // enable Sync for(int i = 0; i < meta->methodCount(); i++ ) { - if(proxy->syncMap(caller).contains(meta->method(i).signature())) + if(isSyncMethod(i)) QMetaObject::connect(caller, i, this, QObject::staticMetaObject.methodCount() + i); } } else if (_sync && !sync) { // disable Sync for(int i = 0; i < meta->methodCount(); i++ ) { - if(proxy->syncMap(caller).contains(meta->method(i).signature())) + if(isSyncMethod(i)) QMetaObject::disconnect(caller, i, this, QObject::staticMetaObject.methodCount() + i); } } _sync = sync; } +bool SignalRelay::isSyncMethod(int i) { + QByteArray signature = caller->metaObject()->method(i).signature(); + if(!proxy->syncMap(caller).contains(signature)) + return false; + + if(proxy->proxyMode() == SignalProxy::Server && !signature.startsWith("request")) + return true; + + if(proxy->proxyMode() == SignalProxy::Client && signature.startsWith("request")) + return true; + + return false; +} + bool SignalRelay::synchronize() const { return _sync; } @@ -422,39 +438,29 @@ bool SignalProxy::attachSlot(const QByteArray& sigName, QObject* recv, const cha } void SignalProxy::synchronize(QObject *obj) { - if(proxyMode() == Server) - return synchronizeAsMaster(obj); - else - return synchronizeAsSlave(obj); -} - -void SignalProxy::synchronizeAsMaster(QObject *sender) { - createClassInfo(sender); + createClassInfo(obj); + // attaching all the Signals SignalRelay* relay; - if(_relayHash.contains(sender)) - relay = _relayHash[sender]; + if(_relayHash.contains(obj)) + relay = _relayHash[obj]; else - relay = _relayHash[sender] = new SignalRelay(this, sender); + relay = _relayHash[obj] = new SignalRelay(this, obj); relay->setSynchronize(true); - if(sender->metaObject()->indexOfSignal(QMetaObject::normalizedSignature("renameObject(QString, QString)")) != -1) - connect(sender, SIGNAL(renameObject(QString, QString)), this, SLOT(objectRenamed(QString, QString)), Qt::DirectConnection); + // attaching as slave to receive sync Calls + QByteArray className(obj->metaObject()->className()); + _syncSlave[className][obj->objectName()] = obj; - QByteArray className(sender->metaObject()->className()); - _syncSlave[className][sender->objectName()] = sender; + if(proxyMode() == Server) { + if(obj->metaObject()->indexOfSignal(QMetaObject::normalizedSignature("renameObject(QString, QString)")) != -1) + connect(obj, SIGNAL(renameObject(QString, QString)), this, SLOT(objectRenamed(QString, QString)), Qt::DirectConnection); - setInitialized(sender); -} - -void SignalProxy::synchronizeAsSlave(QObject *receiver) { - QByteArray className(receiver->metaObject()->className()); - _syncSlave[className][receiver->objectName()] = receiver; - - createClassInfo(receiver); - - requestInit(receiver); + setInitialized(obj); + } else { + requestInit(obj); + } } void SignalProxy::setInitialized(QObject *obj) { diff --git a/src/common/signalproxy.h b/src/common/signalproxy.h index bf3742db..23dbc9f2 100644 --- a/src/common/signalproxy.h +++ b/src/common/signalproxy.h @@ -64,8 +64,6 @@ public: bool attachSlot(const QByteArray& sigName, QObject *recv, const char *slot); void synchronize(QObject *obj); - void synchronizeAsMaster(QObject *obj); - void synchronizeAsSlave(QObject *obj); void setInitialized(QObject *obj); bool initialized(QObject *obj); -- 2.20.1