xref: /aosp_15_r20/external/clang/test/SemaTemplate/constructor-template.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -verify %s
2*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s
3*67e74705SXin Li // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
4*67e74705SXin Li 
5*67e74705SXin Li struct X0 { // expected-note {{candidate constructor (the implicit copy constructor) not viable}}
6*67e74705SXin Li #if __cplusplus >= 201103L // C++11 or later
7*67e74705SXin Li // expected-note@-2 {{candidate constructor (the implicit move constructor) not viable}}
8*67e74705SXin Li #endif
9*67e74705SXin Li   X0(int); // expected-note{{candidate}}
10*67e74705SXin Li   template<typename T> X0(T); // expected-note {{candidate}}
11*67e74705SXin Li   template<typename T, typename U> X0(T*, U*); // expected-note {{candidate}}
12*67e74705SXin Li 
13*67e74705SXin Li   // PR4761
X0X014*67e74705SXin Li   template<typename T> X0() : f0(T::foo) {} // expected-note {{candidate}}
15*67e74705SXin Li   int f0;
16*67e74705SXin Li };
17*67e74705SXin Li 
18*67e74705SXin Li void accept_X0(X0);
19*67e74705SXin Li 
test_X0(int i,float f)20*67e74705SXin Li void test_X0(int i, float f) {
21*67e74705SXin Li   X0 x0a(i);
22*67e74705SXin Li   X0 x0b(f);
23*67e74705SXin Li   X0 x0c = i;
24*67e74705SXin Li   X0 x0d = f;
25*67e74705SXin Li   accept_X0(i);
26*67e74705SXin Li   accept_X0(&i);
27*67e74705SXin Li   accept_X0(f);
28*67e74705SXin Li   accept_X0(&f);
29*67e74705SXin Li   X0 x0e(&i, &f);
30*67e74705SXin Li   X0 x0f(&f, &i);
31*67e74705SXin Li 
32*67e74705SXin Li   X0 x0g(f, &i); // expected-error{{no matching constructor}}
33*67e74705SXin Li }
34*67e74705SXin Li 
35*67e74705SXin Li template<typename T>
36*67e74705SXin Li struct X1 {
37*67e74705SXin Li   X1(const X1&);
38*67e74705SXin Li   template<typename U> X1(const X1<U>&);
39*67e74705SXin Li };
40*67e74705SXin Li 
41*67e74705SXin Li template<typename T>
42*67e74705SXin Li struct Outer {
43*67e74705SXin Li   typedef X1<T> A;
44*67e74705SXin Li 
45*67e74705SXin Li   A alloc;
46*67e74705SXin Li 
OuterOuter47*67e74705SXin Li   explicit Outer(const A& a) : alloc(a) { }
48*67e74705SXin Li };
49*67e74705SXin Li 
test_X1(X1<int> xi)50*67e74705SXin Li void test_X1(X1<int> xi) {
51*67e74705SXin Li   Outer<int> oi(xi);
52*67e74705SXin Li   Outer<float> of(xi);
53*67e74705SXin Li }
54*67e74705SXin Li 
55*67e74705SXin Li // PR4655
56*67e74705SXin Li template<class C> struct A {};
57*67e74705SXin Li template <> struct A<int>{A(const A<int>&);};
BB58*67e74705SXin Li struct B { A<int> x; B(B& a) : x(a.x) {} };
59*67e74705SXin Li 
60*67e74705SXin Li struct X2 {
61*67e74705SXin Li   X2(); // expected-note{{candidate constructor}}
62*67e74705SXin Li   X2(X2&);	// expected-note {{candidate constructor}}
63*67e74705SXin Li   template<typename T> X2(T); // expected-note {{candidate template ignored: instantiation would take its own class type by value}}
64*67e74705SXin Li };
65*67e74705SXin Li 
test(bool Cond,X2 x2)66*67e74705SXin Li X2 test(bool Cond, X2 x2) {
67*67e74705SXin Li   if (Cond)
68*67e74705SXin Li     return x2; // okay, uses copy constructor
69*67e74705SXin Li 
70*67e74705SXin Li   return X2(); // expected-error{{no matching constructor}}
71*67e74705SXin Li }
72*67e74705SXin Li 
73*67e74705SXin Li struct X3 {
74*67e74705SXin Li   template<typename T> X3(T);
75*67e74705SXin Li };
76*67e74705SXin Li 
77*67e74705SXin Li template<> X3::X3(X3); // expected-error{{must pass its first argument by reference}}
78*67e74705SXin Li 
79*67e74705SXin Li struct X4 {
80*67e74705SXin Li   X4();
81*67e74705SXin Li   ~X4();
82*67e74705SXin Li   X4(X4&);
83*67e74705SXin Li   template<typename T> X4(const T&, int = 17);
84*67e74705SXin Li };
85*67e74705SXin Li 
test_X4(bool Cond,X4 x4)86*67e74705SXin Li X4 test_X4(bool Cond, X4 x4) {
87*67e74705SXin Li   X4 a(x4, 17); // okay, constructor template
88*67e74705SXin Li   X4 b(x4); // okay, copy constructor
89*67e74705SXin Li   return X4();
90*67e74705SXin Li }
91*67e74705SXin Li 
92*67e74705SXin Li // Instantiation of a non-dependent use of a constructor
93*67e74705SXin Li struct DefaultCtorHasDefaultArg {
94*67e74705SXin Li   explicit DefaultCtorHasDefaultArg(int i = 17);
95*67e74705SXin Li };
96*67e74705SXin Li 
97*67e74705SXin Li template<typename T>
default_ctor_inst()98*67e74705SXin Li void default_ctor_inst() {
99*67e74705SXin Li   DefaultCtorHasDefaultArg def;
100*67e74705SXin Li }
101*67e74705SXin Li 
102*67e74705SXin Li template void default_ctor_inst<int>();
103*67e74705SXin Li 
104*67e74705SXin Li template<typename T>
105*67e74705SXin Li struct X5 {
106*67e74705SXin Li   X5();
107*67e74705SXin Li   X5(const T &);
108*67e74705SXin Li };
109*67e74705SXin Li 
110*67e74705SXin Li struct X6 {
111*67e74705SXin Li   template<typename T> X6(T);
112*67e74705SXin Li };
113*67e74705SXin Li 
test_X5_X6()114*67e74705SXin Li void test_X5_X6() {
115*67e74705SXin Li   X5<X6> tf;
116*67e74705SXin Li   X5<X6> tf2(tf);
117*67e74705SXin Li }
118*67e74705SXin Li 
119*67e74705SXin Li namespace PR8182 {
120*67e74705SXin Li   struct foo {
121*67e74705SXin Li     foo();
122*67e74705SXin Li     template<class T> foo(T&);
123*67e74705SXin Li 
124*67e74705SXin Li   private:
125*67e74705SXin Li     foo(const foo&);
126*67e74705SXin Li   };
127*67e74705SXin Li 
test_foo()128*67e74705SXin Li   void test_foo() {
129*67e74705SXin Li     foo f1;
130*67e74705SXin Li     foo f2(f1);
131*67e74705SXin Li     foo f3 = f1;
132*67e74705SXin Li   }
133*67e74705SXin Li 
134*67e74705SXin Li }
135*67e74705SXin Li 
136*67e74705SXin Li // Don't blow out the stack trying to call an illegal constructor
137*67e74705SXin Li // instantiation.  We intentionally allow implicit instantiations to
138*67e74705SXin Li // exist, so make sure they're unusable.
139*67e74705SXin Li //
140*67e74705SXin Li // rdar://19199836
141*67e74705SXin Li namespace self_by_value {
142*67e74705SXin Li   template <class T, class U> struct A {
Aself_by_value::A143*67e74705SXin Li     A() {}
Aself_by_value::A144*67e74705SXin Li     A(const A<T,U> &o) {}
Aself_by_value::A145*67e74705SXin Li     A(A<T,T> o) {}
146*67e74705SXin Li   };
147*67e74705SXin Li 
148*67e74705SXin Li   void helper(A<int,float>);
149*67e74705SXin Li 
test1(A<int,int> a)150*67e74705SXin Li   void test1(A<int,int> a) {
151*67e74705SXin Li     helper(a);
152*67e74705SXin Li   }
test2()153*67e74705SXin Li   void test2() {
154*67e74705SXin Li     helper(A<int,int>());
155*67e74705SXin Li   }
156*67e74705SXin Li }
157*67e74705SXin Li 
158*67e74705SXin Li namespace self_by_value_2 {
159*67e74705SXin Li   template <class T, class U> struct A {
Aself_by_value_2::A160*67e74705SXin Li     A() {} // expected-note {{not viable: requires 0 arguments}}
Aself_by_value_2::A161*67e74705SXin Li     A(A<T,U> &o) {} // expected-note {{not viable: expects an l-value}}
Aself_by_value_2::A162*67e74705SXin Li     A(A<T,T> o) {} // expected-note {{ignored: instantiation takes its own class type by value}}
163*67e74705SXin Li   };
164*67e74705SXin Li 
165*67e74705SXin Li   void helper_A(A<int,int>); // expected-note {{passing argument to parameter here}}
test_A()166*67e74705SXin Li   void test_A() {
167*67e74705SXin Li     helper_A(A<int,int>()); // expected-error {{no matching constructor}}
168*67e74705SXin Li   }
169*67e74705SXin Li }
170*67e74705SXin Li 
171*67e74705SXin Li namespace self_by_value_3 {
172*67e74705SXin Li   template <class T, class U> struct A {
Aself_by_value_3::A173*67e74705SXin Li     A() {}
Aself_by_value_3::A174*67e74705SXin Li     A(A<T,U> &o) {}
Aself_by_value_3::A175*67e74705SXin Li     A(A<T,T> o) {}
176*67e74705SXin Li   };
177*67e74705SXin Li 
178*67e74705SXin Li   void helper_A(A<int,int>);
test_A(A<int,int> b)179*67e74705SXin Li   void test_A(A<int,int> b) {
180*67e74705SXin Li     helper_A(b);
181*67e74705SXin Li   }
182*67e74705SXin Li }
183