// RUN: %clang_cc1 -fsyntax-only -verify %s template<typename T> class C { C(int a0 = 0); }; template<> C<char>::C(int a0); struct S { }; // expected-note 3 {{candidate constructor (the implicit copy constructor)}} template<typename T> void f1(T a, T b = 10) { } // expected-error{{no viable conversion}} \ // expected-note{{passing argument to parameter 'b' here}} template<typename T> void f2(T a, T b = T()) { } template<typename T> void f3(T a, T b = T() + T()); // expected-error{{invalid operands to binary expression ('S' and 'S')}} void g() { f1(10); f1(S()); // expected-note{{in instantiation of default function argument expression for 'f1<S>' required here}} f2(10); f2(S()); f3(10); f3(S()); // expected-note{{in instantiation of default function argument expression for 'f3<S>' required here}} } template<typename T> struct F { F(T t = 10); // expected-error{{no viable conversion}} \ // expected-note{{passing argument to parameter 't' here}} void f(T t = 10); // expected-error{{no viable conversion}} \ // expected-note{{passing argument to parameter 't' here}} }; struct FD : F<int> { }; void g2() { F<int> f; FD fd; } void g3(F<int> f, F<struct S> s) { f.f(); s.f(); // expected-note{{in instantiation of default function argument expression for 'f<S>' required here}} F<int> f2; F<S> s2; // expected-note{{in instantiation of default function argument expression for 'F<S>' required here}} } template<typename T> struct G { G(T) {} }; void s(G<int> flags = 10) { } // Test default arguments template<typename T> struct X0 { void f(T = T()); // expected-error{{no matching}} }; template<typename U> void X0<U>::f(U) { } void test_x0(X0<int> xi) { xi.f(); xi.f(17); } struct NotDefaultConstructible { // expected-note 2{{candidate}} NotDefaultConstructible(int); // expected-note 2{{candidate}} }; void test_x0_not_default_constructible(X0<NotDefaultConstructible> xn) { xn.f(NotDefaultConstructible(17)); xn.f(42); xn.f(); // expected-note{{in instantiation of default function argument}} } template<typename T> struct X1 { typedef T value_type; X1(const value_type& value = value_type()); }; void test_X1() { X1<int> x1; } template<typename T> struct X2 { void operator()(T = T()); // expected-error{{no matching}} }; void test_x2(X2<int> x2i, X2<NotDefaultConstructible> x2n) { x2i(); x2i(17); x2n(NotDefaultConstructible(17)); x2n(); // expected-note{{in instantiation of default function argument}} } // PR5283 namespace PR5283 { template<typename T> struct A { A(T = 1); // expected-error 3 {{cannot initialize a parameter of type 'int *' with an rvalue of type 'int'}} \ // expected-note 3{{passing argument to parameter here}} }; struct B : A<int*> { B(); }; B::B() { } // expected-note {{in instantiation of default function argument expression for 'A<int *>' required he}} struct C : virtual A<int*> { C(); }; C::C() { } // expected-note {{in instantiation of default function argument expression for 'A<int *>' required he}} struct D { D(); A<int*> a; }; D::D() { } // expected-note {{in instantiation of default function argument expression for 'A<int *>' required he}} } // PR5301 namespace pr5301 { void f(int, int = 0); template <typename T> void g(T, T = 0); template <int I> void i(int a = I); template <typename T> void h(T t) { f(0); g(1); g(t); i<2>(); } void test() { h(0); } } // PR5810 namespace PR5810 { template<typename T> struct allocator { allocator() { int a[sizeof(T) ? -1 : -1]; } // expected-error2 {{array with a negative size}} }; template<typename T> struct vector { vector(const allocator<T>& = allocator<T>()) {} // expected-note2 {{instantiation of}} }; struct A { }; struct B { }; template<typename> void FilterVTs() { vector<A> Result; } void f() { vector<A> Result; } template<typename T> struct X { vector<B> bs; X() { } }; void f2() { X<float> x; // expected-note{{member function}} } } template<typename T> void f4(T, int = 17); template<> void f4<int>(int, int); void f4_test(int i) { f4(i); } // Instantiate for initialization namespace InstForInit { template<typename T> struct Ptr { typedef T* type; Ptr(type); }; template<typename T> struct Holder { Holder(int i, Ptr<T> ptr = 0); }; void test_holder(int i) { Holder<int> h(i); } }; namespace PR5810b { template<typename T> T broken() { T t; double**** not_it = t; } void f(int = broken<int>()); void g() { f(17); } } namespace PR5810c { template<typename T> struct X { X() { T t; double *****p = t; // expected-error{{cannot initialize a variable of type 'double *****' with an lvalue of type 'int'}} } X(const X&) { } }; struct Y : X<int> { // expected-note{{instantiation of}} }; void f(Y y = Y()); void g() { f(); } } namespace PR8127 { template< typename T > class PointerClass { public: PointerClass( T * object_p ) : p_( object_p ) { p_->acquire(); } private: T * p_; }; class ExternallyImplementedClass; class MyClass { void foo( PointerClass<ExternallyImplementedClass> = 0 ); }; } namespace rdar8427926 { template<typename T> struct Boom { ~Boom() { T t; double *******ptr = t; // expected-error 2{{cannot initialize}} } }; Boom<float> *bfp; struct X { void f(Boom<int> = Boom<int>()) { } // expected-note{{requested here}} void g(int x = (delete bfp, 0)); // expected-note{{requested here}} }; void test(X *x) { x->f(); x->g(); } } namespace PR8401 { template<typename T> struct A { A() { T* x = 1; } // expected-error{{cannot initialize a variable of type 'int *' with an rvalue of type 'int'}} }; template<typename T> struct B { B(const A<T>& a = A<T>()); // expected-note{{in instantiation of}} }; void f(B<int> b = B<int>()); void g() { f(); } }