// RUN: %clang_cc1 -fsyntax-only -verify %s
// PR5741
namespace test0 {
struct A {
struct B { };
struct C;
};
struct A::C : B { };
}
// Test that successive base specifiers don't screw with each other.
namespace test1 {
struct Opaque1 {};
struct Opaque2 {};
struct A {
struct B { B(Opaque1); };
};
struct B {
B(Opaque2);
};
struct C : A, B {
// Apparently the base-or-member lookup is actually ambiguous
// without this qualification.
C() : A(), test1::B(Opaque2()) {}
};
}
// Test that we don't find the injected class name when parsing base
// specifiers.
namespace test2 {
template <class T> struct bar {};
template <class T> struct foo : bar<foo> {}; // expected-error {{use of class template 'foo' requires template arguments}} expected-note {{template is declared here}}
}