From f12e470665c66101baf3a52fca0737b5102d5420 Mon Sep 17 00:00:00 2001 From: Marcelo Lira Date: Wed, 19 Oct 2011 14:27:36 -0300 Subject: Fixes setting of template argument's usage pattern. Comes with an unit test. Reviewed by Hugo Parente Reviewed by Luciano Wolf --- tests/testcontainer.cpp | 42 +++++++++++++++++++++++++++++++++++++++++- 1 file changed, 41 insertions(+), 1 deletion(-) (limited to 'tests/testcontainer.cpp') diff --git a/tests/testcontainer.cpp b/tests/testcontainer.cpp index 563b75c20..3d31f8a61 100644 --- a/tests/testcontainer.cpp +++ b/tests/testcontainer.cpp @@ -38,7 +38,7 @@ void TestContainer::testContainerType() };\ "; const char* xmlCode = "\ - \ + \ \ \ \ @@ -54,6 +54,46 @@ void TestContainer::testContainerType() QCOMPARE(reinterpret_cast(classA->typeEntry()->baseContainerType())->type(), ContainerTypeEntry::ListContainer); } +void TestContainer::testListOfValueType() +{ + const char* cppCode ="\ + namespace std {\ + template\ + class list { \ + T get(int x) { return 0; }\ + };\ + }\ + class ValueType {};\ + class A : public std::list {\ + };\ + "; + const char* xmlCode = "\ + \ + \ + \ + \ + \ + "; + + TestUtil t(cppCode, xmlCode, true); + AbstractMetaClassList classes = t.builder()->classes(); + QCOMPARE(classes.count(), 3); + + AbstractMetaClass* classA = classes.findClass("A"); + QVERIFY(classA); + QCOMPARE(classA->templateBaseClassInstantiations().count(), 1); + const AbstractMetaType* templateInstanceType = classA->templateBaseClassInstantiations().first(); + QVERIFY(templateInstanceType); + + QCOMPARE(templateInstanceType->indirections(), 0); + QVERIFY(!templateInstanceType->typeEntry()->isObject()); + QVERIFY(templateInstanceType->typeEntry()->isValue()); + QVERIFY(!templateInstanceType->isReference()); + QVERIFY(!templateInstanceType->isObject()); + QVERIFY(!templateInstanceType->isValuePointer()); + QVERIFY(templateInstanceType->isValue()); +} + QTEST_APPLESS_MAIN(TestContainer) #include "testcontainer.moc" -- cgit v1.2.3