xref: /llvm-project/clang/test/CXX/drs/cwg22xx.cpp (revision 14ba3f9d07ea1664497c5d117120fb243ca221aa)
1d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++98 -triple x86_64-unknown-unknown %s -verify=expected -fexceptions -fcxx-exceptions -pedantic-errors
2d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++11 -triple x86_64-unknown-unknown %s -verify=expected,since-cxx11 -fexceptions -fcxx-exceptions -pedantic-errors
3d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++14 -triple x86_64-unknown-unknown %s -verify=expected,since-cxx11 -fexceptions -fcxx-exceptions -pedantic-errors
4d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++17 -triple x86_64-unknown-unknown %s -verify=expected,since-cxx11 -fexceptions -fcxx-exceptions -pedantic-errors
5d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++20 -triple x86_64-unknown-unknown %s -verify=expected,since-cxx11 -fexceptions -fcxx-exceptions -pedantic-errors
6d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++23 -triple x86_64-unknown-unknown %s -verify=expected,since-cxx11 -fexceptions -fcxx-exceptions -pedantic-errors
7d358b2deSVlad Serebrennikov // RUN: %clang_cc1 -std=c++2c -triple x86_64-unknown-unknown %s -verify=expected,since-cxx11 -fexceptions -fcxx-exceptions -pedantic-errors
8d358b2deSVlad Serebrennikov 
9d358b2deSVlad Serebrennikov 
10d358b2deSVlad Serebrennikov namespace cwg2211 { // cwg2211: 8
11463e61a0SVlad Serebrennikov #if __cplusplus >= 201103L
12d358b2deSVlad Serebrennikov void f() {
13d358b2deSVlad Serebrennikov   int a;
14d358b2deSVlad Serebrennikov   auto f = [a](int a) { (void)a; };
15d358b2deSVlad Serebrennikov   // since-cxx11-error@-1 {{a lambda parameter cannot shadow an explicitly captured entity}}
16d358b2deSVlad Serebrennikov   //   since-cxx11-note@-2 {{variable 'a' is explicitly captured here}}
17d358b2deSVlad Serebrennikov   auto g = [=](int a) { (void)a; };
18d358b2deSVlad Serebrennikov }
19d358b2deSVlad Serebrennikov #endif
20463e61a0SVlad Serebrennikov } // namespace cwg2211
21d358b2deSVlad Serebrennikov 
22*14ba3f9dSVlad Serebrennikov namespace cwg2213 { // cwg2213: 2.7
23d358b2deSVlad Serebrennikov template <typename T, typename U>
24d358b2deSVlad Serebrennikov struct A;
25d358b2deSVlad Serebrennikov 
26d358b2deSVlad Serebrennikov template <typename U>
27d358b2deSVlad Serebrennikov struct A<int, U>;
28d358b2deSVlad Serebrennikov } // namespace cwg2213
29d358b2deSVlad Serebrennikov 
30d358b2deSVlad Serebrennikov namespace cwg2229 { // cwg2229: 7
31d358b2deSVlad Serebrennikov struct AnonBitfieldQualifiers {
32d358b2deSVlad Serebrennikov   const unsigned : 1;
33d358b2deSVlad Serebrennikov   // expected-error@-1 {{anonymous bit-field cannot have qualifiers}}
34d358b2deSVlad Serebrennikov   volatile unsigned : 1;
35d358b2deSVlad Serebrennikov   // expected-error@-1 {{anonymous bit-field cannot have qualifiers}}
36d358b2deSVlad Serebrennikov   const volatile unsigned : 1;
37d358b2deSVlad Serebrennikov   // expected-error@-1 {{anonymous bit-field cannot have qualifiers}}
38d358b2deSVlad Serebrennikov 
39d358b2deSVlad Serebrennikov   unsigned : 1;
40d358b2deSVlad Serebrennikov   const unsigned i1 : 1;
41d358b2deSVlad Serebrennikov   volatile unsigned i2 : 1;
42d358b2deSVlad Serebrennikov   const volatile unsigned i3 : 1;
43d358b2deSVlad Serebrennikov };
44463e61a0SVlad Serebrennikov } // namespace cwg2229
45d358b2deSVlad Serebrennikov 
46d358b2deSVlad Serebrennikov namespace cwg2233 { // cwg2233: 11
47d358b2deSVlad Serebrennikov #if __cplusplus >= 201103L
48d358b2deSVlad Serebrennikov template <typename... T>
49d358b2deSVlad Serebrennikov void f(int i = 0, T... args) {}
50d358b2deSVlad Serebrennikov 
51d358b2deSVlad Serebrennikov template <typename... T>
52d358b2deSVlad Serebrennikov void g(int i = 0, T... args, T... args2) {}
53d358b2deSVlad Serebrennikov 
54d358b2deSVlad Serebrennikov template <typename... T>
55d358b2deSVlad Serebrennikov void h(int i = 0, T... args, int j = 1) {}
56d358b2deSVlad Serebrennikov 
57d358b2deSVlad Serebrennikov template <typename... T, typename... U>
58d358b2deSVlad Serebrennikov void i(int i = 0, T... args, int j = 1, U... args2) {}
59d358b2deSVlad Serebrennikov 
60d358b2deSVlad Serebrennikov template <class... Ts>
61d358b2deSVlad Serebrennikov void j(int i = 0, Ts... ts) {}
62d358b2deSVlad Serebrennikov 
63d358b2deSVlad Serebrennikov template <>
64d358b2deSVlad Serebrennikov void j<int>(int i, int j) {}
65d358b2deSVlad Serebrennikov 
66d358b2deSVlad Serebrennikov template
67d358b2deSVlad Serebrennikov void j(int, int, int);
68d358b2deSVlad Serebrennikov 
69d358b2deSVlad Serebrennikov extern template
70d358b2deSVlad Serebrennikov void j(int, int, int, int);
71d358b2deSVlad Serebrennikov 
72d358b2deSVlad Serebrennikov // PR23029
73d358b2deSVlad Serebrennikov // Ensure instantiating the templates works.
74d358b2deSVlad Serebrennikov void use() {
75d358b2deSVlad Serebrennikov   f();
76d358b2deSVlad Serebrennikov   f(0, 1);
77d358b2deSVlad Serebrennikov   f<int>(1, 2);
78d358b2deSVlad Serebrennikov   g<int>(1, 2, 3);
79d358b2deSVlad Serebrennikov   h(0, 1);
80d358b2deSVlad Serebrennikov   i();
81d358b2deSVlad Serebrennikov   i(3);
82d358b2deSVlad Serebrennikov   i<int>(3, 2);
83d358b2deSVlad Serebrennikov   i<int>(3, 2, 1);
84d358b2deSVlad Serebrennikov   i<int, int>(1, 2, 3, 4, 5);
85d358b2deSVlad Serebrennikov   j();
86d358b2deSVlad Serebrennikov   j(1);
87d358b2deSVlad Serebrennikov   j(1, 2);
88d358b2deSVlad Serebrennikov   j<int>(1, 2);
89d358b2deSVlad Serebrennikov }
90d358b2deSVlad Serebrennikov 
91d358b2deSVlad Serebrennikov namespace MultilevelSpecialization {
92d358b2deSVlad Serebrennikov   template<typename ...T> struct A {
93d358b2deSVlad Serebrennikov     template <T... V> void f(int i = 0, int (&... arr)[V]);
94d358b2deSVlad Serebrennikov   };
95d358b2deSVlad Serebrennikov   template<> template<>
96d358b2deSVlad Serebrennikov     void A<int, int>::f<1, 1>(int i, int (&arr1a)[1], int (&arr2a)[1]) {}
97d358b2deSVlad Serebrennikov 
98d358b2deSVlad Serebrennikov   // FIXME: I believe this example is valid, at least up to the first explicit
99d358b2deSVlad Serebrennikov   // specialization, but Clang can't cope with explicit specializations that
100d358b2deSVlad Serebrennikov   // expand packs into a sequence of parameters. If we ever start accepting
101d358b2deSVlad Serebrennikov   // that, we'll need to decide whether it's OK for arr1a to be missing its
102d358b2deSVlad Serebrennikov   // default argument -- how far back do we look when determining whether a
103d358b2deSVlad Serebrennikov   // parameter was expanded from a pack?
104d358b2deSVlad Serebrennikov   //   -- zygoloid 2020-06-02
1058282c58dSc8ef   template<typename ...T> struct B { // #cwg2233-B
106d358b2deSVlad Serebrennikov     template <T... V> void f(int i = 0, int (&... arr)[V]);
107d358b2deSVlad Serebrennikov   };
108d358b2deSVlad Serebrennikov   template<> template<int a, int b>
109d358b2deSVlad Serebrennikov     void B<int, int>::f(int i, int (&arr1)[a], int (&arr2)[b]) {}
110d358b2deSVlad Serebrennikov     // since-cxx11-error@-1 {{out-of-line definition of 'f' does not match any declaration in 'cwg2233::MultilevelSpecialization::B<int, int>'}}
1118282c58dSc8ef     //   since-cxx11-note@#cwg2233-B {{defined here}}
112d358b2deSVlad Serebrennikov   template<> template<>
113d358b2deSVlad Serebrennikov     void B<int, int>::f<1, 1>(int i, int (&arr1a)[1], int (&arr2a)[1]) {}
114d358b2deSVlad Serebrennikov }
115d358b2deSVlad Serebrennikov 
116d358b2deSVlad Serebrennikov namespace CheckAfterMerging1 {
117d358b2deSVlad Serebrennikov   template <typename... T> void f() {
118d358b2deSVlad Serebrennikov     void g(int, int = 0);
119d358b2deSVlad Serebrennikov     void g(int = 0, T...);
120d358b2deSVlad Serebrennikov     g();
121d358b2deSVlad Serebrennikov   }
122d358b2deSVlad Serebrennikov   void h() { f<int>(); }
123d358b2deSVlad Serebrennikov }
124d358b2deSVlad Serebrennikov 
125d358b2deSVlad Serebrennikov namespace CheckAfterMerging2 {
126d358b2deSVlad Serebrennikov   template <typename... T> void f() {
127d358b2deSVlad Serebrennikov     void g(int = 0, T...);
128d358b2deSVlad Serebrennikov     void g(int, int = 0);
129d358b2deSVlad Serebrennikov     g();
130d358b2deSVlad Serebrennikov   }
131d358b2deSVlad Serebrennikov   void h() { f<int>(); }
132d358b2deSVlad Serebrennikov }
133d358b2deSVlad Serebrennikov #endif
134d358b2deSVlad Serebrennikov } // namespace cwg2233
135d358b2deSVlad Serebrennikov 
136d358b2deSVlad Serebrennikov namespace cwg2267 { // cwg2267: no
137d358b2deSVlad Serebrennikov #if __cplusplus >= 201103L
138d358b2deSVlad Serebrennikov struct A {} a;
139d358b2deSVlad Serebrennikov struct B { explicit B(const A&); }; // #cwg2267-struct-B
140d358b2deSVlad Serebrennikov 
141d358b2deSVlad Serebrennikov struct D { D(); };
142d358b2deSVlad Serebrennikov struct C { explicit operator D(); } c;
143d358b2deSVlad Serebrennikov 
144d358b2deSVlad Serebrennikov B b1(a);
145d358b2deSVlad Serebrennikov const B &b2{a}; // FIXME ill-formed
146d358b2deSVlad Serebrennikov const B &b3(a);
147d358b2deSVlad Serebrennikov // since-cxx11-error@-1 {{no viable conversion from 'struct A' to 'const B'}}
148d358b2deSVlad Serebrennikov //   since-cxx11-note@#cwg2267-struct-B {{candidate constructor (the implicit copy constructor) not viable: no known conversion from 'struct A' to 'const B &' for 1st argument}}
149d358b2deSVlad Serebrennikov //   since-cxx11-note@#cwg2267-struct-B {{candidate constructor (the implicit move constructor) not viable: no known conversion from 'struct A' to 'B &&' for 1st argument}}
150d358b2deSVlad Serebrennikov //   since-cxx11-note@#cwg2267-struct-B {{explicit constructor is not a candidate}}
151d358b2deSVlad Serebrennikov 
152d358b2deSVlad Serebrennikov D d1(c);
153d358b2deSVlad Serebrennikov const D &d2{c}; // FIXME ill-formed
154d358b2deSVlad Serebrennikov const D &d3(c); // FIXME ill-formed
155d358b2deSVlad Serebrennikov #endif
156463e61a0SVlad Serebrennikov } // namespace cwg2267
157d358b2deSVlad Serebrennikov 
158d358b2deSVlad Serebrennikov namespace cwg2273 { // cwg2273: 3.3
159d358b2deSVlad Serebrennikov #if __cplusplus >= 201103L
160d358b2deSVlad Serebrennikov struct A {
161d358b2deSVlad Serebrennikov   A(int = 0) = delete; // #cwg2273-A
162d358b2deSVlad Serebrennikov };
163d358b2deSVlad Serebrennikov 
164d358b2deSVlad Serebrennikov struct B : A { // #cwg2273-B
165d358b2deSVlad Serebrennikov   using A::A;
166d358b2deSVlad Serebrennikov };
167d358b2deSVlad Serebrennikov 
168d358b2deSVlad Serebrennikov B b;
169d358b2deSVlad Serebrennikov // since-cxx11-error@-1 {{call to implicitly-deleted default constructor of 'B'}}
170d358b2deSVlad Serebrennikov //   since-cxx11-note@#cwg2273-B {{default constructor of 'B' is implicitly deleted because base class 'A' has a deleted default constructor}}
171d358b2deSVlad Serebrennikov //   since-cxx11-note@#cwg2273-A {{'A' has been explicitly marked deleted here}}
172d358b2deSVlad Serebrennikov #endif
173463e61a0SVlad Serebrennikov } // namespace cwg2273
174d358b2deSVlad Serebrennikov 
175d358b2deSVlad Serebrennikov namespace cwg2277 { // cwg2277: partial
176d358b2deSVlad Serebrennikov #if __cplusplus >= 201103L
177d358b2deSVlad Serebrennikov struct A {
178d358b2deSVlad Serebrennikov   A(int, int = 0);
179d358b2deSVlad Serebrennikov   void f(int, int = 0); // #cwg2277-A-f
180d358b2deSVlad Serebrennikov };
181d358b2deSVlad Serebrennikov struct B : A {
182d358b2deSVlad Serebrennikov   B(int);
183d358b2deSVlad Serebrennikov   using A::A;
184d358b2deSVlad Serebrennikov 
185d358b2deSVlad Serebrennikov   void f(int); // #cwg2277-B-f
186d358b2deSVlad Serebrennikov   using A::f;
187d358b2deSVlad Serebrennikov };
188d358b2deSVlad Serebrennikov 
189d358b2deSVlad Serebrennikov void g() {
190d358b2deSVlad Serebrennikov   B b{0};
191d358b2deSVlad Serebrennikov   b.f(0); // FIXME: this is well-formed for the same reason as initialization of 'b' above
192d358b2deSVlad Serebrennikov   // since-cxx11-error@-1 {{call to member function 'f' is ambiguous}}
193d358b2deSVlad Serebrennikov   //   since-cxx11-note@#cwg2277-A-f {{candidate function}}
194d358b2deSVlad Serebrennikov   //   since-cxx11-note@#cwg2277-B-f {{candidate function}}
195d358b2deSVlad Serebrennikov }
196d358b2deSVlad Serebrennikov #endif
197463e61a0SVlad Serebrennikov } // namespace cwg2277
198d358b2deSVlad Serebrennikov 
199d358b2deSVlad Serebrennikov namespace cwg2292 { // cwg2292: 9
200d358b2deSVlad Serebrennikov #if __cplusplus >= 201103L
201d358b2deSVlad Serebrennikov   template<typename T> using id = T;
202d358b2deSVlad Serebrennikov   void test(int *p) {
203d358b2deSVlad Serebrennikov     p->template id<int>::~id<int>();
204d358b2deSVlad Serebrennikov   }
205d358b2deSVlad Serebrennikov #endif
206463e61a0SVlad Serebrennikov } // namespace cwg2292
207