// RUN: clang-cc -fsyntax-only -verify %s struct X0 { // expected-note{{candidate}} X0(int); // expected-note{{candidate}} template X0(T); template X0(T*, U*); // PR4761 template X0() : f0(T::foo) {} int f0; }; void accept_X0(X0); void test_X0(int i, float f) { X0 x0a(i); X0 x0b(f); X0 x0c = i; X0 x0d = f; accept_X0(i); accept_X0(&i); accept_X0(f); accept_X0(&f); X0 x0e(&i, &f); X0 x0f(&f, &i); X0 x0g(f, &i); // expected-error{{no matching constructor}} } template struct X1 { X1(const X1&); template X1(const X1&); }; template struct Outer { typedef X1 A; A alloc; explicit Outer(const A& a) : alloc(a) { } }; void test_X1(X1 xi) { Outer oi(xi); Outer of(xi); } // PR4655 template struct A {}; template <> struct A{A(const A&);}; struct B { A x; B(B& a) : x(a.x) {} }; struct X2 { X2(); X2(X2&); // expected-note {{candidate function}} template X2(T); }; X2 test(bool Cond, X2 x2) { if (Cond) return x2; // okay, uses copy constructor return X2(); // expected-error{{no viable conversion from 'struct X2' to 'struct X2' is possible}} } struct X3 { template X3(T); }; template<> X3::X3(X3); // expected-error{{must pass its first argument by reference}} struct X4 { X4(); ~X4(); X4(X4&); // expected-note {{candidate function}} template X4(const T&, int = 17); }; X4 test_X4(bool Cond, X4 x4) { X4 a(x4, 17); // okay, constructor template X4 b(x4); // okay, copy constructor return X4(); // expected-error{{no viable conversion}} }