[PATCH 3/5] fixup the usebuilder, the codegenerator, and the duchain test
Floris Ruijter
flo.ruijt at hotmail.com
Sat Feb 5 04:23:56 UTC 2011
---
languages/cpp/cppduchain/tests/test_duchain.cpp | 64 +++++++++++++++++++++++
languages/cpp/cppduchain/tests/test_duchain.h | 1 +
languages/cpp/cppduchain/usebuilder.cpp | 2 +-
languages/cpp/parser/codegenerator.cpp | 3 +-
4 files changed, 67 insertions(+), 3 deletions(-)
diff --git a/languages/cpp/cppduchain/tests/test_duchain.cpp b/languages/cpp/cppduchain/tests/test_duchain.cpp
index e9789a0..87308e6 100644
--- a/languages/cpp/cppduchain/tests/test_duchain.cpp
+++ b/languages/cpp/cppduchain/tests/test_duchain.cpp
@@ -5846,5 +5846,69 @@ void TestDUChain::testCommentAfterFunctionCall()
QVERIFY(top->childContexts().last()->localDeclarations().isEmpty());
QCOMPARE(m_view->uses().size(), 1);
}
+void TestDUChain::testPointerToMember()
+{
+ // 1 2 3
+ // 123456789012345678901234567890
+ LockedTopDUContext top = parse( "struct AA {"
+ "\n int j;"
+ "\n};"
+ "\nstruct BB{"
+ "\n int AA::* pj;"
+ "\n};"
+ "\nvoid f(int AA::* par){"
+ "\n BB b;"
+ "\n int AA::* BB::* ppj=&BB::pj;"
+ "\n b.*ppj=par;"
+ "\n}",DumpAll
+ );
+ QVERIFY(top);
+ DUChainReadLocker lock;
+ QVERIFY(top->problems().isEmpty());
+ QCOMPARE(top->childContexts().size(),4);
+ QCOMPARE(top->localDeclarations().size(),3);
+
+ QCOMPARE(top->localDeclarations().at(0)->uses().begin()->size(),3);
+ QCOMPARE(top->localDeclarations().at(1)->uses().begin()->size(),3);
+
+ QCOMPARE(top->localDeclarations().at(0)->uses().begin()->at(0),RangeInRevision(4,6,4,8));
+ QCOMPARE(top->localDeclarations().at(0)->uses().begin()->at(1),RangeInRevision(6,11,6,13));
+ QCOMPARE(top->localDeclarations().at(0)->uses().begin()->at(2),RangeInRevision(8,6,8,8));
+
+ QCOMPARE(top->localDeclarations().at(1)->uses().begin()->at(0),RangeInRevision(7,2,7,4));
+ QCOMPARE(top->localDeclarations().at(1)->uses().begin()->at(1),RangeInRevision(8,12,8,14));
+ QCOMPARE(top->localDeclarations().at(1)->uses().begin()->at(2),RangeInRevision(8,23,8,25));
+
+ {
+ DUContext* ctx = top->childContexts().at(1);
+ Declaration* dec = ctx->localDeclarations().first();
+ PtrToMemberType::Ptr type = dec->abstractType().cast<PtrToMemberType>();
+ QVERIFY(type);
+ StructureType::Ptr structType = type->ClassType().cast<StructureType>();
+ QVERIFY(structType);
+ QCOMPARE(structType->qualifiedIdentifier().toString(), QString("AA"));
+ }
+ {
+ DUContext* ctx = top->childContexts().at(3);
+ Declaration* dec = ctx->localDeclarations().at(1);
+ PtrToMemberType::Ptr type = dec->abstractType().cast<PtrToMemberType>();
+
+ {
+ QVERIFY(type);
+ StructureType::Ptr structType = type->ClassType().cast<StructureType>();
+ QVERIFY(structType);
+ QCOMPARE(structType->qualifiedIdentifier().toString(), QString("BB"));
+ }
+
+ PtrToMemberType::Ptr ptype = type->baseType().cast<PtrToMemberType>();
+ {
+ QVERIFY(ptype);
+ StructureType::Ptr structType = ptype->ClassType().cast<StructureType>();
+ QVERIFY(structType);
+ QCOMPARE(structType->qualifiedIdentifier().toString(), QString("AA"));
+ }
+ }
+
+}
#include "test_duchain.moc"
diff --git a/languages/cpp/cppduchain/tests/test_duchain.h b/languages/cpp/cppduchain/tests/test_duchain.h
index 4cd7d05..23efbb0 100644
--- a/languages/cpp/cppduchain/tests/test_duchain.h
+++ b/languages/cpp/cppduchain/tests/test_duchain.h
@@ -190,6 +190,7 @@ private slots:
void testAutoTypes();
void testCommentAfterFunctionCall();
+ void testPointerToMember();
private:
void assertNoMemberFunctionModifiers(KDevelop::ClassFunctionDeclaration* memberFun);
diff --git a/languages/cpp/cppduchain/usebuilder.cpp b/languages/cpp/cppduchain/usebuilder.cpp
index 68b08fb..dc5bb2f 100644
--- a/languages/cpp/cppduchain/usebuilder.cpp
+++ b/languages/cpp/cppduchain/usebuilder.cpp
@@ -233,7 +233,7 @@ void UseBuilder::visitSimpleDeclaration(SimpleDeclarationAST* node)
}
it = it->next;
} while (it != end);
- }else{
+ } else {
DefaultVisitor::visitSimpleDeclaration(node);
}
}
diff --git a/languages/cpp/parser/codegenerator.cpp b/languages/cpp/parser/codegenerator.cpp
index fcdb04c..3cb23dc 100644
--- a/languages/cpp/parser/codegenerator.cpp
+++ b/languages/cpp/parser/codegenerator.cpp
@@ -612,8 +612,7 @@ void CodeGenerator::visitPtrOperator(PtrOperatorAST* node)
void CodeGenerator::visitPtrToMember(PtrToMemberAST* node)
{
- // TODO fix AST
- Q_UNUSED(node);
+ visit(node->class_type);
printToken(Token_scope);
m_output << "*";
}
--
1.7.2.3
--=-jnTU9w3TPwGq4NfAnuZF
Content-Disposition: attachment; filename="0004-rename-ClassType-to-classType.patch"
Content-Type: text/x-patch; name="0004-rename-ClassType-to-classType.patch"; charset="UTF-8"
Content-Transfer-Encoding: 7bit
More information about the KDevelop-devel
mailing list