+ int callType = params.takeFirst().value<int>();
+
+ switch(callType) {
+ case RpcCall:
+ if(params.empty()) {
+ qWarning() << "SignalProxy::receivePeerSignal(): received empty RPC-Call";
+ return;
+ } else {
+ return handleSignal(params.takeFirst().toByteArray(), params);
+ }
+ case Sync:
+ return handleSync(params);
+ case InitRequest:
+ return handleInitRequest(sender, params);
+ case InitData:
+ return handleInitData(sender, params);
+ case HeartBeat:
+ return;
+ default:
+ qWarning() << "SignalProxy::receivePeerSignal(): received undefined CallType" << callType << params;
+ return;
+ }
+}
+
+void SignalProxy::handleSync(QVariantList params) {
+ if(params.count() < 3) {
+ qWarning() << "received invalid Sync call" << params;
+ return;
+ }
+
+ QByteArray className = params.takeFirst().toByteArray();
+ QString objectName = params.takeFirst().toString();
+ QByteArray signal = params.takeFirst().toByteArray();
+
+ if(!_syncSlave.contains(className) || !_syncSlave[className].contains(objectName)) {
+ qWarning() << QString("no registered receiver for sync call: %1::%2 (objectName=\"%3\"). Params are:").arg(QString(className)).arg(QString(signal)).arg(objectName)
+ << params;
+ return;
+ }
+
+ SyncableObject *receiver = _syncSlave[className][objectName];
+ if(!syncMap(receiver).contains(signal)) {
+ qWarning() << QString("no matching slot for sync call: %1::%2 (objectName=\"%3\"). Params are:").arg(QString(className)).arg(QString(signal)).arg(objectName)
+ << params;
+ return;
+ }
+
+ int slotId = syncMap(receiver)[signal];
+ if(!invokeSlot(receiver, slotId, params)) {
+ qWarning("SignalProxy::handleSync(): invokeMethod for \"%s\" failed ", methodName(receiver, slotId).constData());
+ return;
+ }
+ invokeSlot(receiver, updatedRemotelyId(receiver));
+}
+
+void SignalProxy::handleInitRequest(QIODevice *sender, const QVariantList ¶ms) {
+ if(params.count() != 2) {
+ qWarning() << "SignalProxy::handleInitRequest() received initRequest with invalid param Count:"
+ << params;
+ return;
+ }
+
+ QByteArray className(params[0].toByteArray());
+ QString objectName(params[1].toString());
+
+ if(!_syncSlave.contains(className)) {
+ qWarning() << "SignalProxy::handleInitRequest() received initRequest for unregistered Class:"
+ << className;
+ return;
+ }
+
+ if(!_syncSlave[className].contains(objectName)) {
+ qWarning() << "SignalProxy::handleInitRequest() received initRequest for unregistered Object:"
+ << className << objectName;
+ return;
+ }
+
+ SyncableObject *obj = _syncSlave[className][objectName];
+
+ QVariantList params_;
+ params_ << obj->metaObject()->className()
+ << obj->objectName()
+ << initData(obj);
+
+ dispatchSignal(sender, InitData, params_);
+}
+
+void SignalProxy::handleInitData(QIODevice *sender, const QVariantList ¶ms) {
+ Q_UNUSED(sender)
+ if(params.count() != 3) {
+ qWarning() << "SignalProxy::handleInitData() received initData with invalid param Count:"
+ << params;
+ return;
+ }
+
+ QByteArray className(params[0].toByteArray());
+ QString objectName(params[1].toString());
+ QVariantMap propertyMap(params[2].toMap());
+
+ if(!_syncSlave.contains(className)) {
+ qWarning() << "SignalProxy::handleInitData() received initData for unregistered Class:"
+ << className;
+ return;
+ }
+
+ if(!_syncSlave[className].contains(objectName)) {
+ qWarning() << "SignalProxy::handleInitData() received initData for unregistered Object:"
+ << className << objectName;
+ return;
+ }
+
+ SyncableObject *obj = _syncSlave[className][objectName];
+ setInitData(obj, propertyMap);
+}
+
+void SignalProxy::handleSignal(const QByteArray &funcName, const QVariantList ¶ms) {
+ QObject* receiver;
+ int methodId;