summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppcompletion_test.cpp
diff options
context:
space:
mode:
authorErik Verbruggen <erik.verbruggen@digia.com>2012-10-18 15:06:13 +0200
committerErik Verbruggen <erik.verbruggen@digia.com>2012-10-19 14:42:32 +0200
commit2b95d81cd826c0f7f6c681f425da3b53c76aa140 (patch)
tree75176828a331893ed3a1090fff1dc86e762f0d83 /src/plugins/cpptools/cppcompletion_test.cpp
parentfa655dd40784346db8fb3fd47d54e59c7e7e5763 (diff)
downloadqt-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.cpp70
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"));
}