2009-12-16 04:14:24 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s
|
2009-08-22 02:42:58 +08:00
|
|
|
struct X0 { // expected-note{{candidate}}
|
|
|
|
X0(int); // expected-note{{candidate}}
|
2009-12-16 16:11:27 +08:00
|
|
|
template<typename T> X0(T); // expected-note {{candidate}}
|
|
|
|
template<typename T, typename U> X0(T*, U*); // expected-note {{candidate}}
|
2009-08-24 19:57:43 +08:00
|
|
|
|
|
|
|
// PR4761
|
2009-12-16 16:11:27 +08:00
|
|
|
template<typename T> X0() : f0(T::foo) {} // expected-note {{candidate}}
|
2009-08-24 19:57:43 +08:00
|
|
|
int f0;
|
2009-08-22 02:42:58 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
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}}
|
|
|
|
}
|
2009-09-16 02:26:13 +08:00
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
struct X1 {
|
|
|
|
X1(const X1&);
|
|
|
|
template<typename U> X1(const X1<U>&);
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
struct Outer {
|
|
|
|
typedef X1<T> A;
|
|
|
|
|
|
|
|
A alloc;
|
|
|
|
|
|
|
|
explicit Outer(const A& a) : alloc(a) { }
|
|
|
|
};
|
|
|
|
|
|
|
|
void test_X1(X1<int> xi) {
|
|
|
|
Outer<int> oi(xi);
|
|
|
|
Outer<float> of(xi);
|
|
|
|
}
|
2009-09-16 05:14:05 +08:00
|
|
|
|
|
|
|
// PR4655
|
|
|
|
template<class C> struct A {};
|
|
|
|
template <> struct A<int>{A(const A<int>&);};
|
|
|
|
struct B { A<int> x; B(B& a) : x(a.x) {} };
|
2009-11-03 09:35:08 +08:00
|
|
|
|
2009-11-14 09:20:54 +08:00
|
|
|
struct X2 {
|
|
|
|
X2();
|
2009-11-19 02:26:29 +08:00
|
|
|
X2(X2&); // expected-note {{candidate function}}
|
2009-11-14 09:20:54 +08:00
|
|
|
template<typename T> X2(T);
|
|
|
|
};
|
|
|
|
|
|
|
|
X2 test(bool Cond, X2 x2) {
|
|
|
|
if (Cond)
|
|
|
|
return x2; // okay, uses copy constructor
|
|
|
|
|
2009-11-19 02:26:29 +08:00
|
|
|
return X2(); // expected-error{{no viable conversion from 'struct X2' to 'struct X2' is possible}}
|
2009-11-14 09:20:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
struct X3 {
|
|
|
|
template<typename T> X3(T);
|
|
|
|
};
|
|
|
|
|
|
|
|
template<> X3::X3(X3); // expected-error{{must pass its first argument by reference}}
|
|
|
|
|
|
|
|
struct X4 {
|
|
|
|
X4();
|
|
|
|
~X4();
|
2009-11-19 02:26:29 +08:00
|
|
|
X4(X4&); // expected-note {{candidate function}}
|
2009-11-14 09:20:54 +08:00
|
|
|
template<typename T> 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
|
2009-11-19 02:26:29 +08:00
|
|
|
return X4(); // expected-error{{no viable conversion}}
|
2009-11-14 09:20:54 +08:00
|
|
|
}
|
2009-12-15 03:27:10 +08:00
|
|
|
|
|
|
|
// Instantiation of a non-dependent use of a constructor
|
|
|
|
struct DefaultCtorHasDefaultArg {
|
|
|
|
explicit DefaultCtorHasDefaultArg(int i = 17);
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
void default_ctor_inst() {
|
|
|
|
DefaultCtorHasDefaultArg def;
|
|
|
|
}
|
|
|
|
|
|
|
|
template void default_ctor_inst<int>();
|