summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/cppcompletion_test.cpp
diff options
context:
space:
mode:
authorPrzemyslaw Gorszkowski <pgorszkowski@gmail.com>2013-05-09 00:34:28 +0200
committerNikolai Kosjar <nikolai.kosjar@digia.com>2013-05-10 11:16:04 +0200
commit5dbcb974b02e788f9c213a917105a4e6b6593281 (patch)
tree7942c2746cf699f40787a69f7cc89d8f51b02357 /src/plugins/cpptools/cppcompletion_test.cpp
parentcd8cd4fdb11e54d241748ed72f480aaf641d1161 (diff)
downloadqt-creator-5dbcb974b02e788f9c213a917105a4e6b6593281.tar.gz
C++: added missing cloning of AnonymousNameId
When instantiate a template with anonymous class/struct/union AnonymousNameId has to be cloned. Task-number: QTCREATORBUG-9227 Change-Id: Iedca5e41589e68a94a35cd4387241052c70c50df Reviewed-by: Sergey Shambir <sergey.shambir.auto@gmail.com> Reviewed-by: Friedemann Kleint <Friedemann.Kleint@digia.com> Reviewed-by: Nikolai Kosjar <nikolai.kosjar@digia.com>
Diffstat (limited to 'src/plugins/cpptools/cppcompletion_test.cpp')
-rw-r--r--src/plugins/cpptools/cppcompletion_test.cpp32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/plugins/cpptools/cppcompletion_test.cpp b/src/plugins/cpptools/cppcompletion_test.cpp
index d231f6f317..385777de30 100644
--- a/src/plugins/cpptools/cppcompletion_test.cpp
+++ b/src/plugins/cpptools/cppcompletion_test.cpp
@@ -2015,3 +2015,35 @@ void CppToolsPlugin::test_completion_type_and_using_declaration_data()
<< code << completions;
}
+
+void CppToolsPlugin::test_completion_instantiate_template_with_anonymous_class()
+{
+ TestData data;
+ data.srcText =
+ "template <typename T>\n"
+ "struct S\n"
+ "{\n"
+ " union { int i; char c; };\n"
+ "};\n"
+ "void fun()\n"
+ "{\n"
+ " S<int> s;\n"
+ " @\n"
+ " // padding so we get the scope right\n"
+ "}\n"
+
+ ;
+ setup(&data);
+
+ Utils::ChangeSet change;
+ QString txt = QLatin1String("s.");
+ change.insert(data.pos, txt);
+ QTextCursor cursor(data.doc);
+ change.apply(&cursor);
+ data.pos += txt.length();
+
+ QStringList completions = getCompletions(data);
+
+ QCOMPARE(completions.size(), 1);
+ QVERIFY(completions.contains(QLatin1String("S")));
+}