QPair: specialise QTypeInfo based on the typeinfos of its arguments
Specialise QTypeInfo<QPair<T1,T2>> based on the properties of T1 and T2: - If either T1 or T2 is Q_COMPLEX_TYPE, so is QPair<T1,T2>. - Otherwise, if either T1 or T2 is Q_MOVABLE_TYPE, so is QPair<T1,T2>. - Otherwise, QPair<T1,T2> is Q_PRIMITIVE_TYPE. Change-Id: I8aecbd37e3b7924f77f38967498deabf1a19ca24 Reviewed-by: Olivier Goffart <ogoffart@woboq.com> Reviewed-by: Thiago Macieira <thiago.macieira@intel.com> Reviewed-by: Stephen Kelly <stephen.kelly@kdab.com>
This commit is contained in:
parent
e174405862
commit
15c141511f
@ -65,6 +65,22 @@ struct QPair
|
||||
T2 second;
|
||||
};
|
||||
|
||||
// mark QPair<T1,T2> as complex/movable/primitive depending on the
|
||||
// typeinfos of the constituents:
|
||||
template<class T1, class T2>
|
||||
class QTypeInfo< QPair<T1, T2> >
|
||||
{
|
||||
public:
|
||||
enum {
|
||||
isComplex = QTypeInfo<T1>::isComplex || QTypeInfo<T2>::isComplex,
|
||||
isStatic = QTypeInfo<T1>::isStatic || QTypeInfo<T2>::isStatic,
|
||||
isLarge = sizeof(QPair<T1, T2>) > sizeof(void*),
|
||||
isPointer = false,
|
||||
isDummy = false,
|
||||
sizeOf = sizeof(QPair<T1, T2>)
|
||||
};
|
||||
};
|
||||
|
||||
template <class T1, class T2>
|
||||
Q_INLINE_TEMPLATE bool operator==(const QPair<T1, T2> &p1, const QPair<T1, T2> &p2)
|
||||
{ return p1.first == p2.first && p1.second == p2.second; }
|
||||
|
@ -682,6 +682,36 @@ public:
|
||||
};
|
||||
Q_DECLARE_METATYPE(CustomMultiInheritanceObject*);
|
||||
|
||||
class C { char _[4]; };
|
||||
class M { char _[4]; };
|
||||
class P { char _[4]; };
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
Q_DECLARE_TYPEINFO(M, Q_MOVABLE_TYPE);
|
||||
Q_DECLARE_TYPEINFO(P, Q_PRIMITIVE_TYPE);
|
||||
QT_END_NAMESPACE
|
||||
|
||||
// avoid the comma:
|
||||
typedef QPair<C,C> QPairCC;
|
||||
typedef QPair<C,M> QPairCM;
|
||||
typedef QPair<C,P> QPairCP;
|
||||
typedef QPair<M,C> QPairMC;
|
||||
typedef QPair<M,M> QPairMM;
|
||||
typedef QPair<M,P> QPairMP;
|
||||
typedef QPair<P,C> QPairPC;
|
||||
typedef QPair<P,M> QPairPM;
|
||||
typedef QPair<P,P> QPairPP;
|
||||
|
||||
Q_DECLARE_METATYPE(QPairCC)
|
||||
Q_DECLARE_METATYPE(QPairCM)
|
||||
Q_DECLARE_METATYPE(QPairCP)
|
||||
Q_DECLARE_METATYPE(QPairMC)
|
||||
Q_DECLARE_METATYPE(QPairMM)
|
||||
Q_DECLARE_METATYPE(QPairMP)
|
||||
Q_DECLARE_METATYPE(QPairPC)
|
||||
Q_DECLARE_METATYPE(QPairPM)
|
||||
Q_DECLARE_METATYPE(QPairPP)
|
||||
|
||||
void tst_QMetaType::flags_data()
|
||||
{
|
||||
QTest::addColumn<int>("type");
|
||||
@ -700,6 +730,15 @@ QT_FOR_EACH_STATIC_CORE_POINTER(ADD_METATYPE_TEST_ROW)
|
||||
QTest::newRow("CustomMovable") << ::qMetaTypeId<CustomMovable>() << true << true << false;
|
||||
QTest::newRow("CustomObject*") << ::qMetaTypeId<CustomObject*>() << true << false << true;
|
||||
QTest::newRow("CustomMultiInheritanceObject*") << ::qMetaTypeId<CustomMultiInheritanceObject*>() << true << false << true;
|
||||
QTest::newRow("QPair<C,C>") << ::qMetaTypeId<QPair<C,C> >() << false << true << false;
|
||||
QTest::newRow("QPair<C,M>") << ::qMetaTypeId<QPair<C,M> >() << false << true << false;
|
||||
QTest::newRow("QPair<C,P>") << ::qMetaTypeId<QPair<C,P> >() << false << true << false;
|
||||
QTest::newRow("QPair<M,C>") << ::qMetaTypeId<QPair<M,C> >() << false << true << false;
|
||||
QTest::newRow("QPair<M,M>") << ::qMetaTypeId<QPair<M,M> >() << true << true << false;
|
||||
QTest::newRow("QPair<M,P>") << ::qMetaTypeId<QPair<M,P> >() << true << true << false;
|
||||
QTest::newRow("QPair<P,C>") << ::qMetaTypeId<QPair<P,C> >() << false << true << false;
|
||||
QTest::newRow("QPair<P,M>") << ::qMetaTypeId<QPair<P,M> >() << true << true << false;
|
||||
QTest::newRow("QPair<P,P>") << ::qMetaTypeId<QPair<P,P> >() << true << false << false;
|
||||
}
|
||||
|
||||
void tst_QMetaType::flags()
|
||||
|
4
tests/auto/corelib/tools/qpair/qpair.pro
Normal file
4
tests/auto/corelib/tools/qpair/qpair.pro
Normal file
@ -0,0 +1,4 @@
|
||||
CONFIG += testcase parallel_test
|
||||
TARGET = tst_qpair
|
||||
QT = core testlib
|
||||
SOURCES = tst_qpair.cpp
|
105
tests/auto/corelib/tools/qpair/tst_qpair.cpp
Normal file
105
tests/auto/corelib/tools/qpair/tst_qpair.cpp
Normal file
@ -0,0 +1,105 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2012 Klarälvdalens Datakonsult AB, a KDAB Group company, info@kdab.com, author Marc Mutz <marc.mutz@kdab.com>
|
||||
** Contact: http://www.qt-project.org/
|
||||
**
|
||||
** This file is part of the test suite of the Qt Toolkit.
|
||||
**
|
||||
** $QT_BEGIN_LICENSE:LGPL$
|
||||
** GNU Lesser General Public License Usage
|
||||
** This file may be used under the terms of the GNU Lesser General Public
|
||||
** License version 2.1 as published by the Free Software Foundation and
|
||||
** appearing in the file LICENSE.LGPL included in the packaging of this
|
||||
** file. Please review the following information to ensure the GNU Lesser
|
||||
** General Public License version 2.1 requirements will be met:
|
||||
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
||||
**
|
||||
** In addition, as a special exception, Nokia gives you certain additional
|
||||
** rights. These rights are described in the Nokia Qt LGPL Exception
|
||||
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU General
|
||||
** Public License version 3.0 as published by the Free Software Foundation
|
||||
** and appearing in the file LICENSE.GPL included in the packaging of this
|
||||
** file. Please review the following information to ensure the GNU General
|
||||
** Public License version 3.0 requirements will be met:
|
||||
** http://www.gnu.org/copyleft/gpl.html.
|
||||
**
|
||||
** Other Usage
|
||||
** Alternatively, this file may be used in accordance with the terms and
|
||||
** conditions contained in a signed written agreement between you and Nokia.
|
||||
**
|
||||
**
|
||||
**
|
||||
**
|
||||
**
|
||||
**
|
||||
** $QT_END_LICENSE$
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#include <QtTest/QtTest>
|
||||
|
||||
#include <QPair>
|
||||
|
||||
class tst_QPair : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
private Q_SLOTS:
|
||||
void dummy() {}
|
||||
};
|
||||
|
||||
class C { char _[4]; };
|
||||
class M { char _[4]; };
|
||||
class P { char _[4]; };
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
Q_DECLARE_TYPEINFO(M, Q_MOVABLE_TYPE);
|
||||
Q_DECLARE_TYPEINFO(P, Q_PRIMITIVE_TYPE);
|
||||
QT_END_NAMESPACE
|
||||
|
||||
// avoid the comma:
|
||||
typedef QPair<C,C> QPairCC;
|
||||
typedef QPair<C,M> QPairCM;
|
||||
typedef QPair<C,P> QPairCP;
|
||||
typedef QPair<M,C> QPairMC;
|
||||
typedef QPair<M,M> QPairMM;
|
||||
typedef QPair<M,P> QPairMP;
|
||||
typedef QPair<P,C> QPairPC;
|
||||
typedef QPair<P,M> QPairPM;
|
||||
typedef QPair<P,P> QPairPP;
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairCC>::isComplex);
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairCC>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairCM>::isComplex);
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairCM>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairCP>::isComplex);
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairCP>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairMC>::isComplex);
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairMC>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairMM>::isComplex);
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairMM>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairMP>::isComplex);
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairMP>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairPC>::isComplex);
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairPC>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT( QTypeInfo<QPairPM>::isComplex);
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairPM>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairPP>::isComplex);
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairPP>::isStatic );
|
||||
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairPP>::isDummy );
|
||||
Q_STATIC_ASSERT(!QTypeInfo<QPairPP>::isPointer);
|
||||
|
||||
|
||||
QTEST_APPLESS_MAIN(tst_QPair)
|
||||
#include "tst_qpair.moc"
|
@ -20,6 +20,7 @@ SUBDIRS=\
|
||||
qlocale \
|
||||
qmap \
|
||||
qmargins \
|
||||
qpair \
|
||||
qpoint \
|
||||
qqueue \
|
||||
qrect \
|
||||
|
Loading…
Reference in New Issue
Block a user