/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the test suite of Qt for Python. ** ** $QT_BEGIN_LICENSE:GPL-EXCEPT$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "testarrayargument.h" #include #include "testutil.h" #include #include #include #include #include void TestArrayArgument::testArrayArgumentWithSizeDefinedByInteger() { const char* cppCode ="\ struct A {\n\ enum SomeEnum { Value0, Value1, NValues };\n\ void method(double[3]);\n\ };\n"; const char* xmlCode = "\ \n\ \n\ \n\ \n\ \n\ \n"; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode, false)); QVERIFY(!builder.isNull()); const AbstractMetaClass *classA = AbstractMetaClass::findClass(builder->classes(), u"A"); QVERIFY(classA); const AbstractMetaArgument &arg = classA->functions().constLast()->arguments().constFirst(); QVERIFY(arg.type().isArray()); QCOMPARE(arg.type().arrayElementCount(), 3); QCOMPARE(arg.type().arrayElementType()->name(), u"double"); } static QString functionMinimalSignature(const AbstractMetaClass *c, const QString &name) { const auto f = c->findFunction(name); return f.isNull() ? QString() : f->minimalSignature(); } void TestArrayArgument::testArraySignature() { const char cppCode[] ="\ struct A {\n\ void mi1(int arg[5]);\n\ void mi1c(const int arg[5]);\n\ void mi1cu(const int arg[]);\n\ void mc1cu(const char arg[]);\n\ void mc1cup(const char *arg[]);\n\ void muc2(unsigned char *arg[2][3]);\n\ void mc2c(const char *arg[5][6]);\n\ void mc2cu(const char arg[][2]);\n\ };\n"; const char xmlCode[] = "\ \n\ \n\ \n\ \n\ \n\ \n"; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode, false)); QVERIFY(!builder.isNull()); const AbstractMetaClass *classA = AbstractMetaClass::findClass(builder->classes(), u"A"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mi1")), u"mi1(int[5])"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mi1c")), u"mi1c(const int[5])"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mi1cu")), u"mi1cu(const int[])"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mc1cu")), u"mc1cu(const char*)"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mc1cup")), u"mc1cup(const char*[])"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("muc2")), u"muc2(unsigned char*[2][3])"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mc2c")), u"mc2c(const char*[5][6])"); QCOMPARE(functionMinimalSignature(classA, QLatin1String("mc2cu")), u"mc2cu(const char[][2])"); } void TestArrayArgument::testArrayArgumentWithSizeDefinedByEnumValue() { const char* cppCode ="\ struct A {\n\ enum SomeEnum { Value0, Value1, NValues };\n\ void method(double[NValues]);\n\ };\n"; const char* xmlCode = "\ \n\ \n\ \n\ \n\ \n\ \n"; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode, false)); QVERIFY(!builder.isNull()); AbstractMetaClass *classA = AbstractMetaClass::findClass(builder->classes(), u"A"); QVERIFY(classA); auto someEnum = classA->findEnum(QLatin1String("SomeEnum")); QVERIFY(someEnum.has_value()); auto nvalues = classA->findEnumValue(QLatin1String("NValues")); QVERIFY(nvalues.has_value()); const AbstractMetaArgument &arg = classA->functions().constLast()->arguments().constFirst(); QVERIFY(arg.type().isArray()); QCOMPARE(arg.type().arrayElementCount(), nvalues->value().value()); QCOMPARE(arg.type().arrayElementType()->name(), u"double"); }; void TestArrayArgument::testArrayArgumentWithSizeDefinedByEnumValueFromGlobalEnum() { const char* cppCode ="\ enum SomeEnum { Value0, Value1, NValues };\n\ struct A {\n\ void method(double[NValues]);\n\ };\n"; const char* xmlCode = "\ \n\ \n\ \n\ \n\ \n\ \n"; QScopedPointer builder(TestUtil::parse(cppCode, xmlCode, false)); QVERIFY(!builder.isNull()); const AbstractMetaClass *classA = AbstractMetaClass::findClass(builder->classes(), u"A"); QVERIFY(classA); AbstractMetaEnum someEnum = builder->globalEnums().constFirst(); auto nvalues = someEnum.findEnumValue(u"NValues"); QVERIFY(nvalues.has_value()); const AbstractMetaArgument &arg = classA->functions().constLast()->arguments().constFirst(); QVERIFY(arg.type().isArray()); QCOMPARE(arg.type().arrayElementCount(), nvalues->value().value()); QCOMPARE(arg.type().arrayElementType()->name(), u"double"); }; QTEST_APPLESS_MAIN(TestArrayArgument)