summaryrefslogtreecommitdiffstats
path: root/src/corelib/kernel/qobject.h
diff options
context:
space:
mode:
authorOlivier Goffart <ogoffart@woboq.com>2011-11-25 22:35:32 +0100
committerQt by Nokia <qt-info@nokia.com>2011-11-29 17:11:59 +0100
commit0dec6250f7538c79c4698c3952a46105bc264e4e (patch)
treeea7dc9079fd990346fb1dd0e3e4a6cf87fc8a514 /src/corelib/kernel/qobject.h
parent8350d91245ff122d03c628ea297a808d86103cd1 (diff)
Support Qt::UniqueConnection in the new connection syntax
This commit also improves the related documentation a bit. The test is copied from the test with the old syntax, but all the connection statement are changed to use the new syntax Change-Id: Ia5630ca4335b9f8ca6d724ae3c8750d6f0804d8e Reviewed-by: Bradley T. Hughes <bradley.hughes@nokia.com>
Diffstat (limited to 'src/corelib/kernel/qobject.h')
-rw-r--r--src/corelib/kernel/qobject.h18
1 files changed, 10 insertions, 8 deletions
diff --git a/src/corelib/kernel/qobject.h b/src/corelib/kernel/qobject.h
index 3b8803c1a6..48c0bdbfcb 100644
--- a/src/corelib/kernel/qobject.h
+++ b/src/corelib/kernel/qobject.h
@@ -225,9 +225,9 @@ public:
types = QtPrivate::ConnectionTypes<typename SignalType::Arguments>::types();
return connectImpl(sender, reinterpret_cast<void **>(&signal),
- receiver, new QSlotObject<Func2,
- typename QtPrivate::List_Left<typename SignalType::Arguments, SlotType::ArgumentCount>::Value,
- typename SignalType::ReturnType>(slot),
+ receiver, reinterpret_cast<void **>(&slot),
+ new QSlotObject<Func2, typename QtPrivate::List_Left<typename SignalType::Arguments, SlotType::ArgumentCount>::Value,
+ typename SignalType::ReturnType>(slot),
type, types, &SignalType::Object::staticMetaObject);
}
@@ -243,7 +243,7 @@ public:
typedef typename QtPrivate::CheckCompatibleArguments<typename SignalType::Arguments, typename SlotType::Arguments>::IncompatibleSignalSlotArguments EnsureCompatibleArguments;
typedef typename QtPrivate::QEnableIf<(int(SignalType::ArgumentCount) >= int(SlotType::ArgumentCount))>::Type EnsureArgumentsCount;
- return connectImpl(sender, reinterpret_cast<void **>(&signal), sender,
+ return connectImpl(sender, reinterpret_cast<void **>(&signal), sender, 0,
new QStaticSlotObject<Func2,
typename QtPrivate::List_Left<typename SignalType::Arguments, SlotType::ArgumentCount>::Value,
typename SignalType::ReturnType>(slot),
@@ -257,8 +257,8 @@ public:
{
typedef QtPrivate::FunctionPointer<Func1> SignalType;
- return connectImpl(sender, reinterpret_cast<void **>(&signal),
- sender, new QFunctorSlotObject<Func2, SignalType::ArgumentCount, typename SignalType::Arguments, typename SignalType::ReturnType>(slot),
+ return connectImpl(sender, reinterpret_cast<void **>(&signal), sender, 0,
+ new QFunctorSlotObject<Func2, SignalType::ArgumentCount, typename SignalType::Arguments, typename SignalType::ReturnType>(slot),
Qt::DirectConnection, 0, &SignalType::Object::staticMetaObject);
}
@@ -407,8 +407,10 @@ private:
}
};
- static QMetaObject::Connection connectImpl(const QObject *sender, void **signal, const QObject *receiver, QSlotObjectBase *slot,
- Qt::ConnectionType type, const int *types, const QMetaObject *senderMetaObject);
+ static QMetaObject::Connection connectImpl(const QObject *sender, void **signal,
+ const QObject *receiver, void **slotPtr,
+ QSlotObjectBase *slot, Qt::ConnectionType type,
+ const int *types, const QMetaObject *senderMetaObject);
static bool disconnectImpl(const QObject *sender, void **signal, const QObject *receiver, void **slot,
const QMetaObject *senderMetaObject);