diff options
author | Przemyslaw Gorszkowski <pgorszkowski@gmail.com> | 2013-05-09 00:34:28 +0200 |
---|---|---|
committer | Nikolai Kosjar <nikolai.kosjar@digia.com> | 2013-05-10 11:16:04 +0200 |
commit | 5dbcb974b02e788f9c213a917105a4e6b6593281 (patch) | |
tree | 7942c2746cf699f40787a69f7cc89d8f51b02357 /src/plugins/cpptools/cppcompletion_test.cpp | |
parent | cd8cd4fdb11e54d241748ed72f480aaf641d1161 (diff) | |
download | qt-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.cpp | 32 |
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"))); +} |