// RUN: %clang_cc1 -fsyntax-only -verify %s
// RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s
// RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
template<class X> struct A {};
template<class X> struct B : A<X> {
B() : A<X>() {}
};
B<int> x;
template<class X> struct B1 : A<X> {
typedef A<X> Base;
B1() : Base() {}
};
B1<int> x1;
template<typename T> struct Tmpl { };
template<typename T> struct TmplB { };
struct TmplC : Tmpl<int> {
TmplC() :
Tmpl<int>(),
TmplB<int>() { } // expected-error {{type 'TmplB<int>' is not a direct or virtual base of 'TmplC'}}
};
struct TmplD : Tmpl<char>, TmplB<char> {
TmplD():
Tmpl<int>(), // expected-error {{type 'Tmpl<int>' is not a direct or virtual base of 'TmplD'}}
TmplB<char>() {}
};
namespace PR7259 {
class Base {
public:
Base() {}
};
template <class ParentClass>
class Derived : public ParentClass {
public:
Derived() : Base() {}
};
class Final : public Derived<Base> {
};
int
main (void)
{
Final final;
return 0;
}
}
namespace NonDependentError {
struct Base { Base(int); }; // expected-note {{candidate constructor not viable}}
// expected-note@-1 {{candidate constructor (the implicit copy constructor) not viable}}
#if __cplusplus >= 201103L // C++11 or later
// expected-note@-3 {{candidate constructor (the implicit move constructor) not viable}}
#endif
template<typename T>
struct Derived1 : Base {
Derived1() : Base(1, 2) {} // expected-error {{no matching constructor}}
};
template<typename T>
struct Derived2 : Base {
Derived2() : BaseClass(1) {} // expected-error {{does not name a non-static data member or base}}
};
Derived1<void> d1;
Derived2<void> d2;
}