diff options
| author | Erik Verbruggen <erik.verbruggen@digia.com> | 2012-10-18 15:06:13 +0200 |
|---|---|---|
| committer | Erik Verbruggen <erik.verbruggen@digia.com> | 2012-10-19 14:42:32 +0200 |
| commit | 2b95d81cd826c0f7f6c681f425da3b53c76aa140 (patch) | |
| tree | 75176828a331893ed3a1090fff1dc86e762f0d83 /src/plugins/cpptools/cppcompletion_test.cpp | |
| parent | fa655dd40784346db8fb3fd47d54e59c7e7e5763 (diff) | |
| download | qt-creator-2b95d81cd826c0f7f6c681f425da3b53c76aa140.tar.gz | |
C++: Fix typedef resolving when templates are involved.
Task-number: QTCREATORBUG-7978
Change-Id: I27e6ebe56e410d509580a1e00f8986642cacc5ba
Reviewed-by: David Schulz <david.schulz@digia.com>
Reviewed-by: Eike Ziller <eike.ziller@digia.com>
Reviewed-by: Christian Stenger <christian.stenger@digia.com>
Diffstat (limited to 'src/plugins/cpptools/cppcompletion_test.cpp')
| -rw-r--r-- | src/plugins/cpptools/cppcompletion_test.cpp | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/src/plugins/cpptools/cppcompletion_test.cpp b/src/plugins/cpptools/cppcompletion_test.cpp index 72438d114b..68229c6371 100644 --- a/src/plugins/cpptools/cppcompletion_test.cpp +++ b/src/plugins/cpptools/cppcompletion_test.cpp @@ -296,6 +296,76 @@ void CppToolsPlugin::test_completion_template_3() QVERIFY(completions.contains("Tupple")); QVERIFY(completions.contains("a")); QVERIFY(completions.contains("b")); +} + +void CppToolsPlugin::test_completion_template_4() +{ + TestData data; + data.srcText = "\n" + "template <class T>\n" + "struct List\n" + "{\n" + " typedef T U;\n" + " U u;\n" + "};\n" + "\n" + "struct Tupple { int a; int b; };\n" + "\n" + "void func() {\n" + " List<Tupple> l;\n" + " @\n" + " // padding so we get the scope right\n" + "}"; + + setup(&data); + + Utils::ChangeSet change; + QString txt = QLatin1String("l.u."); + change.insert(data.pos, txt); + QTextCursor cursor(data.doc); + change.apply(&cursor); + data.pos += txt.length(); + + QStringList completions = getCompletions(data); + + QCOMPARE(completions.size(), 3); + QVERIFY(completions.contains("Tupple")); + QVERIFY(completions.contains("a")); + QVERIFY(completions.contains("b")); +} + +void CppToolsPlugin::test_completion_template_5() +{ + TestData data; + data.srcText = "\n" + "template <class T>\n" + "struct List\n" + "{\n" + " T u;\n" + "};\n" + "\n" + "struct Tupple { int a; int b; };\n" + "\n" + "void func() {\n" + " typedef List<Tupple> LT;\n" + " LT l;" + " @\n" + " // padding so we get the scope right\n" + "}"; + + setup(&data); + + Utils::ChangeSet change; + QString txt = QLatin1String("l.u."); + change.insert(data.pos, txt); + QTextCursor cursor(data.doc); + change.apply(&cursor); + data.pos += txt.length(); + + QStringList completions = getCompletions(data); + + QCOMPARE(completions.size(), 3); + QVERIFY(completions.contains("Tupple")); QVERIFY(completions.contains("a")); QVERIFY(completions.contains("b")); } |
