1 // RUN: %clang_cc1 -pedantic -Wall -Wno-unused-but-set-variable -Wno-comment -verify -fcxx-exceptions -x c++ -std=c++98 -Wno-c++14-extensions %s
3 // RUN: not %clang_cc1 -pedantic -Wall -Wno-unused-but-set-variable -Wno-comment -fcxx-exceptions -fixit -x c++ -std=c++98 -Wno-c++14-extensions %t-98
4 // RUN: %clang_cc1 -fsyntax-only -pedantic -Wall -Wno-unused-but-set-variable -Werror -Wno-comment -fcxx-exceptions -x c++ -std=c++98 -Wno-c++14-extensions %t-98
5 // RUN: not %clang_cc1 -fsyntax-only -pedantic -fdiagnostics-parseable-fixits -x c++ -std=c++11 -Wno-c++14-extensions %s 2>&1 | FileCheck %s
6 // RUN: %clang_cc1 -pedantic -Wall -Wno-unused-but-set-variable -Wno-comment -verify -fcxx-exceptions -x c++ -std=c++11 -Wno-c++14-extensions %s
8 // RUN: not %clang_cc1 -pedantic -Wall -Wno-unused-but-set-variable -Wno-comment -fcxx-exceptions -fixit -x c++ -std=c++11 -Wno-c++14-extensions %t-11
9 // RUN: %clang_cc1 -fsyntax-only -pedantic -Wall -Wno-unused-but-set-variable -Werror -Wno-comment -fcxx-exceptions -x c++ -std=c++11 -Wno-c++14-extensions %t-11
11 /* This is a test of the various code modification hints that are
12 provided as part of warning or extension diagnostics. All of the
13 warnings will be fixed by -fixit, and the resulting file should
14 compile cleanly with -Werror -pedantic. */
20 struct C2
: virtual public virtual C1
{ }; // expected-error{{duplicate}}
22 virtual void C1::f() { } // expected-error{{'virtual' can only be specified inside the class definition}}
24 static void C1::g() { } // expected-error{{'static' can only be specified inside the class definition}}
26 template<int Value
> struct CT
{ template<typename
> struct Inner
; }; // expected-note{{previous use is here}}
28 // FIXME: In C++11 this gets 'expected unqualified-id' which fixit can't fix.
29 // Probably parses as `CT<10> > 2 > ct;` rather than `CT<(10 >> 2)> ct;`.
30 #if __cplusplus < 201103L
31 CT
<10 >> 2> ct
; // expected-warning{{require parentheses}}
36 C3(C3
, int i
= 0); // expected-error{{copy constructor must pass its first argument by reference}}
39 struct CT
<0> { }; // expected-error{{'template<>'}}
41 template<> union CT
<1> { }; // expected-error{{tag type}}
43 struct CT
<2>::Inner
<int> { }; // expected-error 2{{'template<>'}}
45 // Access declarations
52 #if __cplusplus >= 201103L
53 A::foo
; // expected-error{{ISO C++11 does not allow access declarations}}
55 A::foo
; // expected-warning{{access declarations are deprecated}}
59 void f() throw(); // expected-note{{previous}}
60 void f(); // expected-error{{missing exception specification}}
62 namespace rdar7853795
{
64 bool getNumComponents() const; // expected-note{{declared here}}
66 getNumComponenets(); // expected-error{{use of undeclared identifier 'getNumComponenets'; did you mean 'getNumComponents'?}}
71 namespace rdar7796492
{
72 struct A
{ int x
, y
; A(); };
75 : x(1) y(2) { // expected-error{{missing ',' between base or member initializers}}
80 // extra qualification on member
82 int C::foo(); // expected-error {{extra qualification}}
85 namespace rdar8488464
{
87 int x1
&= 0; // expected-error {{invalid '&=' at end of declaration; did you mean '='?}}
88 int x2
*= 0; // expected-error {{invalid '*=' at end of declaration; did you mean '='?}}
89 int x3
+= 0; // expected-error {{invalid '+=' at end of declaration; did you mean '='?}}
90 int x4
-= 0; // expected-error {{invalid '-=' at end of declaration; did you mean '='?}}
91 int x5
!= 0; // expected-error {{invalid '!=' at end of declaration; did you mean '='?}}
92 int x6
/= 0; // expected-error {{invalid '/=' at end of declaration; did you mean '='?}}
93 int x7
%= 0; // expected-error {{invalid '%=' at end of declaration; did you mean '='?}}
94 int x8
<= 0; // expected-error {{invalid '<=' at end of declaration; did you mean '='?}}
95 int x9
<<= 0; // expected-error {{invalid '<<=' at end of declaration; did you mean '='?}}
96 int x10
>= 0; // expected-error {{invalid '>=' at end of declaration; did you mean '='?}}
97 int x11
>>= 0; // expected-error {{invalid '>>=' at end of declaration; did you mean '='?}}
98 int x12
^= 0; // expected-error {{invalid '^=' at end of declaration; did you mean '='?}}
99 int x13
|= 0; // expected-error {{invalid '|=' at end of declaration; did you mean '='?}}
100 int x14
== 0; // expected-error {{invalid '==' at end of declaration; did you mean '='?}}
105 int x1
&= 0; // expected-error {{invalid '&=' at end of declaration; did you mean '='?}}
107 int x2
*= 0; // expected-error {{invalid '*=' at end of declaration; did you mean '='?}}
109 int x3
+= 0; // expected-error {{invalid '+=' at end of declaration; did you mean '='?}}
111 int x4
-= 0; // expected-error {{invalid '-=' at end of declaration; did you mean '='?}}
113 int x5
!= 0; // expected-error {{invalid '!=' at end of declaration; did you mean '='?}}
115 int x6
/= 0; // expected-error {{invalid '/=' at end of declaration; did you mean '='?}}
117 int x7
%= 0; // expected-error {{invalid '%=' at end of declaration; did you mean '='?}}
119 int x8
<= 0; // expected-error {{invalid '<=' at end of declaration; did you mean '='?}}
121 int x9
<<= 0; // expected-error {{invalid '<<=' at end of declaration; did you mean '='?}}
123 int x10
>= 0; // expected-error {{invalid '>=' at end of declaration; did you mean '='?}}
125 int x11
>>= 0; // expected-error {{invalid '>>=' at end of declaration; did you mean '='?}}
127 int x12
^= 0; // expected-error {{invalid '^=' at end of declaration; did you mean '='?}}
129 int x13
|= 0; // expected-error {{invalid '|=' at end of declaration; did you mean '='?}}
131 int x14
== 0; // expected-error {{invalid '==' at end of declaration; did you mean '='?}}
133 if (int x
= 0) { (void)x
; }
134 if (int x1
&= 0) { (void)x1
; } // expected-error {{invalid '&=' at end of declaration; did you mean '='?}}
135 if (int x2
*= 0) { (void)x2
; } // expected-error {{invalid '*=' at end of declaration; did you mean '='?}}
136 if (int x3
+= 0) { (void)x3
; } // expected-error {{invalid '+=' at end of declaration; did you mean '='?}}
137 if (int x4
-= 0) { (void)x4
; } // expected-error {{invalid '-=' at end of declaration; did you mean '='?}}
138 if (int x5
!= 0) { (void)x5
; } // expected-error {{invalid '!=' at end of declaration; did you mean '='?}}
139 if (int x6
/= 0) { (void)x6
; } // expected-error {{invalid '/=' at end of declaration; did you mean '='?}}
140 if (int x7
%= 0) { (void)x7
; } // expected-error {{invalid '%=' at end of declaration; did you mean '='?}}
141 if (int x8
<= 0) { (void)x8
; } // expected-error {{invalid '<=' at end of declaration; did you mean '='?}}
142 if (int x9
<<= 0) { (void)x9
; } // expected-error {{invalid '<<=' at end of declaration; did you mean '='?}}
143 if (int x10
>= 0) { (void)x10
; } // expected-error {{invalid '>=' at end of declaration; did you mean '='?}}
144 if (int x11
>>= 0) { (void)x11
; } // expected-error {{invalid '>>=' at end of declaration; did you mean '='?}}
145 if (int x12
^= 0) { (void)x12
; } // expected-error {{invalid '^=' at end of declaration; did you mean '='?}}
146 if (int x13
|= 0) { (void)x13
; } // expected-error {{invalid '|=' at end of declaration; did you mean '='?}}
147 if (int x14
== 0) { (void)x14
; } // expected-error {{invalid '==' at end of declaration; did you mean '='?}}
161 typename F1
<T
>:: /*template*/ Iterator
<0> Mypos
; // expected-error {{use 'template' keyword to treat 'Iterator' as a dependent template name}}
166 typename F1
<T
>:: /*template*/ Iterator
<0> Mypos
; // expected-error {{use 'template' keyword to treat 'Iterator' as a dependent template name}}
169 // Tests for &/* fixits
171 class BD
: public AD
{};
176 aPtr
= b
; // expected-error {{assigning to 'AD *' from incompatible type 'BD'; take the address with &}}
177 aPtr
= br
; // expected-error {{assigning to 'AD *' from incompatible type 'BD'; take the address with &}}
180 void foo1() const {} // expected-error {{non-member function cannot have 'const' qualifier}}
181 void foo2() volatile {} // expected-error {{non-member function cannot have 'volatile' qualifier}}
182 void foo3() const volatile {} // expected-error {{non-member function cannot have 'const volatile' qualifier}}
184 struct S
{ void f(int, char); };
187 oopsAComma(42), // expected-error {{expected ';' at end of declaration}}
188 AD
oopsMoreCommas() {
189 static int n
= 0, // expected-error {{expected ';' at end of declaration}}
191 &d
= c
, // expected-error {{expected ';' at end of declaration}}
192 S s
, // expected-error {{expected ';' at end of declaration}}
194 AD ad
, // expected-error {{expected ';' at end of declaration}}
197 struct MoreAccidentalCommas
{
200 : 4, // expected-error {{expected ';' at end of declaration}}
201 char c
, // expected-error {{expected ';' at end of declaration}}
202 double d
, // expected-error {{expected ';' at end of declaration}}
203 MoreAccidentalCommas
*next
, // expected-error {{expected ';' at end of declaration}}
205 int k
, // expected-error {{expected ';' at end of declaration}}
206 friend void f(MoreAccidentalCommas
) {}
207 int k2
, // expected-error {{expected ';' at end of declaration}}
208 virtual void g(), // expected-error {{expected ';' at end of declaration}}
211 template<class T
> struct Mystery
;
212 template<class T
> typedef Mystery
<T
>::type
getMysteriousThing() { // \
213 expected
-error
{{function definition declared
'typedef'}} \
214 expected
-warning
{{implicit
'typename' is a C
++20 extension
}}
215 return Mystery
<T
>::get();
218 template<template<typename
> Foo
, // expected-error {{template template parameter requires 'class' after the parameter list}}
219 template<typename
> typename Bar
, // expected-warning {{template template parameter using 'typename' is a C++17 extension}}
220 template<typename
> struct Baz
> // expected-error {{template template parameter requires 'class' after the parameter list}}
223 namespace ShadowedTagType
{
227 void SetBar(Bar bar
);
228 Bar
Bar(); // expected-note 2 {{enum 'Bar' is hidden by a non-type declaration of 'Bar' here}}
230 Bar bar_
; // expected-error {{must use 'enum' tag to refer to type 'Bar' in this scope}}
232 void Foo::SetBar(Bar bar
) { bar_
= bar
; } // expected-error {{must use 'enum' tag to refer to type 'Bar' in this scope}}
236 char c
= NULL
; // expected-warning {{implicit conversion of NULL constant to 'char'}}
237 double dbl
= NULL
; // expected-warning {{implicit conversion of NULL constant to 'double'}}
239 namespace arrow_suggest
{
241 template <typename T
>
244 wrapped_ptr(T
* ptr
) : ptr_(ptr
) {}
245 T
* operator->() { return ptr_
; }
256 wrapped_ptr
<Worker
> worker(new Worker
);
257 worker
.DoSomething(); // expected-error {{no member named 'DoSomething' in 'arrow_suggest::wrapped_ptr<arrow_suggest::Worker>'; did you mean to use '->' instead of '.'?}}
260 } // namespace arrow_suggest
262 // Make sure fixing namespace-qualified identifiers functions properly with
263 // namespace-aware typo correction/
264 namespace redecl_typo
{
266 void BeEvil(); // expected-note {{'BeEvil' declared here}}
270 bool isGood(); // expected-note {{'Bar::Foo::isGood' declared here}}
274 bool Foo::isGood() { // expected-error {{out-of-line definition of 'isGood' does not match any declaration in namespace 'redecl_typo::Foo'; did you mean 'Bar::Foo::isGood'?}}
277 void Foo::beEvil() {} // expected-error {{out-of-line definition of 'beEvil' does not match any declaration in namespace 'redecl_typo::Foo'; did you mean 'BeEvil'?}}
280 // Test behavior when a template-id is ended by a token which starts with '>'.
281 namespace greatergreater
{
282 template<typename T
> struct S
{ S(); S(T
); };
283 void f(S
<int>=0); // expected-error {{a space is required between a right angle bracket and an equals sign (use '> =')}}
285 // FIXME: The fix-its here overlap so -fixit mode can't apply the second one.
286 //void f(S<S<int>>=S<int>());
289 template<typename T
> Shr(T
);
290 template<typename T
> void operator >>=(T
);
293 template<template<typename
>> struct TemplateTemplateParam
; // expected-error {{requires 'class'}}
295 template <typename T
> int t
= 0;
298 (void)(t
<int>==p
); // expected-error {{use '> ='}}
299 (void)(t
<int>>=p
); // expected-error {{use '> >'}}
300 #if __cplusplus < 201103L
301 (void)(t
<S
<int>>>=p
); // expected-error {{use '> >'}}
302 (Shr
)t
<S
<int>>>>=p
; // expected-error {{use '> >'}}
305 // FIXME: We correct this to 't<int> > >= p;' not 't<int> >>= p;'
308 // FIXME: The fix-its here overlap.
309 //(void)(t<S<int>>==p);
315 (void)&i
; // expected-error{{must explicitly qualify name of member function when taking its address}}
320 namespace dtor_fixit
{
322 ~bar() { } // expected-error {{undeclared identifier 'bar' in destructor name}}
323 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:6-[[@LINE-1]]:9}:"foo"
326 class bar
{ // expected-note {{found}}
329 ~bar::bar() {} // expected-error {{'~' in destructor name should be after nested name specifier}}
330 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:3-[[@LINE-1]]:4}:""
331 // CHECK: fix-it:"{{.*}}":{[[@LINE-2]]:9-[[@LINE-2]]:9}:"~"
335 template <typename T
> struct X
{};
337 void f(foo
*p
, N::X
<int> *x
) {
338 p
->~undeclared(); // expected-error {{undeclared}}
339 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:9-[[@LINE-1]]:19}:"foo"
341 p
->~bar(); // expected-error {{does not match}}
342 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:9-[[@LINE-1]]:12}:"foo"
344 // FIXME: This is a bad fixit; it'd be better to suggest replacing 'foo'
346 p
->N::T::~foo(); // expected-warning {{requires the name after '::~' to be found in the same scope as the name before}}
347 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:12-[[@LINE-1]]:12}:"::foo"
349 typedef foo baz
; // expected-note {{found}}
350 p
->dtor_fixit::foo::~baz(); // expected-warning {{only found in lexical scope}}
351 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:8-[[@LINE-1]]:25}:""
353 // FIXME: This is a bad fixit; it'd be better to suggest adding the
354 // template arguments.
355 x
->N::X
<int>::~X(); // expected-warning {{same scope}}
356 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:17-[[@LINE-1]]:17}:"::X"
361 template<typename T
> struct X
{};
362 X
<int *p
> x
; // expected-error {{type-id cannot have a name}}
370 const char* foo(A
&x
)
372 return x
.str
.(); // expected-error {{unexpected '.' in function call; perhaps remove the '.'?}}
374 bool bar(A x
, const char *y
) {
375 return foo
->(x
) == y
; // expected-error {{unexpected '->' in function call; perhaps remove the '->'?}}
387 return c
->a
; // expected-error {{member reference type 'Cl0' is not a pointer; did you mean to use '.'?}}
391 namespace curly_after_base_clause
{
392 struct A
{ void f(); };
393 struct B
: A
// expected-error{{expected '{' after base class list}}
394 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
397 struct C
: A
// expected-error{{expected '{' after base class list}}
398 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
401 struct D
: A
// expected-error{{expected '{' after base class list}}
402 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
405 struct E
: A
// expected-error{{expected '{' after base class list}}
406 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
407 template<typename T
> struct inner
{ };
409 struct F
: A
// expected-error{{expected '{' after base class list}}
410 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
413 #if __cplusplus >= 201103L
414 struct G
: A
// expected-error{{expected '{' after base class list}}
415 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
418 struct H
: A
// expected-error{{expected '{' after base class list}}
419 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:13-[[@LINE-1]]:13}:" {"
420 static_assert(true, "");
425 struct conversion_operator
{
426 conversion_operator::* const operator int(); // expected-error {{put the complete type after 'operator'}}
427 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:3-[[@LINE-1]]:32}:""
428 // CHECK: fix-it:"{{.*}}":{[[@LINE-2]]:44-[[@LINE-2]]:44}:" conversion_operator::* const"
431 struct const_zero_init
{
434 const const_zero_init czi
; // expected-error {{default initialization of an object of const type 'const const_zero_init'}}
435 // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:26-[[@LINE-1]]:26}:"{}"
438 namespace dotPointerDestructor
{
445 o
.~Bar(); // expected-error {{member reference type 'Bar *' is a pointer; did you mean to use '->'}}
446 } // CHECK: fix-it:"{{.*}}":{[[@LINE-1]]:4-[[@LINE-1]]:5}:"->"