forked from qt-creator/qt-creator
Revert "C++: fix support for typedef of templated typedefs"
Infinite recursion in the lookup of:
struct common_type {
public:
typedef typename common_type<typename common_type<_Tp, _Up>::type,
V>::type type;
};
This reverts commit 9a56ce4e85bec81c521258f44e9076d0bc9cce92
Change-Id: I675fe39018789cd04127d105eb983d2cb7798ca5
Reviewed-by: Erik Verbruggen <erik.verbruggen@digia.com>
This commit is contained in:
@@ -1882,77 +1882,3 @@ void CppToolsPlugin::test_completion_QTCREATORBUG9098()
|
||||
QVERIFY(completions.contains(QLatin1String("c")));
|
||||
QVERIFY(completions.contains(QLatin1String("B")));
|
||||
}
|
||||
|
||||
void CppToolsPlugin::test_completion_typedef_of_templated_typedef_QTCREATORBUG8375()
|
||||
{
|
||||
TestData data;
|
||||
data.srcText =
|
||||
"struct Foo\n"
|
||||
"{ void bar(); };\n"
|
||||
"struct A\n"
|
||||
"{ typedef Foo AFoo; };\n"
|
||||
"template <class T>\n"
|
||||
"struct B\n"
|
||||
"{ typedef typename T::AFoo BFoo; };\n"
|
||||
"struct C : public B<A>\n"
|
||||
"{\n"
|
||||
" void test()\n"
|
||||
" {\n"
|
||||
" BFoo foo;\n"
|
||||
" @\n"
|
||||
" // padding so we get the scope right\n"
|
||||
" }\n"
|
||||
"};\n"
|
||||
;
|
||||
setup(&data);
|
||||
|
||||
Utils::ChangeSet change;
|
||||
QString txt = QLatin1String("foo.");
|
||||
change.insert(data.pos, txt);
|
||||
QTextCursor cursor(data.doc);
|
||||
change.apply(&cursor);
|
||||
data.pos += txt.length();
|
||||
|
||||
QStringList completions = getCompletions(data);
|
||||
|
||||
QCOMPARE(completions.size(), 2);
|
||||
QVERIFY(completions.contains(QLatin1String("Foo")));
|
||||
QVERIFY(completions.contains(QLatin1String("bar")));
|
||||
}
|
||||
|
||||
void CppToolsPlugin::test_completion_typedef_with_the_same_base_name_and_new_type_name()
|
||||
{
|
||||
TestData data;
|
||||
data.srcText =
|
||||
"namespace A\n"
|
||||
"{\n"
|
||||
"struct A { int aa; };\n"
|
||||
"}\n"
|
||||
"struct S\n"
|
||||
"{\n"
|
||||
" typedef A::A A;\n"
|
||||
" A a;\n"
|
||||
"};\n"
|
||||
"void fun()\n"
|
||||
"{\n"
|
||||
" S s;\n"
|
||||
" @\n"
|
||||
" // padding so we get the scope right\n"
|
||||
"};\n"
|
||||
;
|
||||
setup(&data);
|
||||
|
||||
Utils::ChangeSet change;
|
||||
QString txt = QLatin1String("s.a.");
|
||||
change.insert(data.pos, txt);
|
||||
QTextCursor cursor(data.doc);
|
||||
change.apply(&cursor);
|
||||
data.pos += txt.length();
|
||||
|
||||
QStringList completions = getCompletions(data);
|
||||
|
||||
QCOMPARE(completions.size(), 2);
|
||||
QVERIFY(completions.contains(QLatin1String("A")));
|
||||
QVERIFY(completions.contains(QLatin1String("aa")));
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user