forked from qt-creator/qt-creator
Merge remote-tracking branch 'origin/2.7' into 2.8
Conflicts: src/plugins/cpptools/cppcompletion_test.cpp src/plugins/cpptools/cpptoolsplugin.h src/plugins/qbsprojectmanager/qbsbuildstep.cpp src/plugins/qbsprojectmanager/qbscleanstep.cpp src/plugins/qbsprojectmanager/qbsnodes.cpp src/shared/qbs Change-Id: I8fc97ed61c47af2c3d9e5cc2bf81e97661204d4e
This commit is contained in:
@@ -2239,3 +2239,37 @@ void CppToolsPlugin::test_completion_instantiate_template_function()
|
||||
QVERIFY(completions.contains(QLatin1String("A")));
|
||||
QVERIFY(completions.contains(QLatin1String("a")));
|
||||
}
|
||||
|
||||
void CppToolsPlugin::test_completion_crash_cloning_template_class_QTCREATORBUG9329()
|
||||
{
|
||||
TestData data;
|
||||
data.srcText =
|
||||
"struct A {};\n"
|
||||
"template <typename T>\n"
|
||||
"struct Templ {};\n"
|
||||
"struct B : A, Templ<A>\n"
|
||||
"{\n"
|
||||
" int f()\n"
|
||||
" {\n"
|
||||
" @\n"
|
||||
" // padding so we get the scope right\n"
|
||||
" }\n"
|
||||
"};\n"
|
||||
;
|
||||
setup(&data);
|
||||
|
||||
Utils::ChangeSet change;
|
||||
QString txt = QLatin1String("this->");
|
||||
change.insert(data.pos, txt);
|
||||
QTextCursor cursor(data.doc);
|
||||
change.apply(&cursor);
|
||||
data.pos += txt.length();
|
||||
|
||||
QStringList completions = getCompletions(data);
|
||||
|
||||
QCOMPARE(completions.size(), 4);
|
||||
QVERIFY(completions.contains(QLatin1String("A")));
|
||||
QVERIFY(completions.contains(QLatin1String("B")));
|
||||
QVERIFY(completions.contains(QLatin1String("Templ")));
|
||||
QVERIFY(completions.contains(QLatin1String("f")));
|
||||
}
|
||||
|
||||
@@ -137,6 +137,7 @@ private slots:
|
||||
void test_completion_type_and_using_declaration_data();
|
||||
void test_completion_instantiate_template_with_anonymous_class();
|
||||
void test_completion_instantiate_template_function();
|
||||
void test_completion_crash_cloning_template_class_QTCREATORBUG9329();
|
||||
|
||||
void test_format_pointerdeclaration_in_simpledeclarations();
|
||||
void test_format_pointerdeclaration_in_simpledeclarations_data();
|
||||
|
||||
Reference in New Issue
Block a user