| // RUN: %clang_cc1 -Wno-int-to-pointer-cast -fsyntax-only -verify -pedantic-errors %s |
| // RUN: %clang_cc1 -Wno-int-to-pointer-cast -fsyntax-only -verify -pedantic-errors -std=gnu++98 %s |
| // RUN: %clang_cc1 -Wno-int-to-pointer-cast -fsyntax-only -verify -pedantic-errors -std=gnu++11 %s |
| // RUN: %clang_cc1 -Wno-int-to-pointer-cast -fsyntax-only -verify -pedantic-errors -x objective-c++ %s |
| |
| void f() { |
| int a; |
| struct S { int m; }; |
| typedef S *T; |
| |
| // Expressions. |
| T(a)->m = 7; |
| int(a)++; // expected-error {{assignment to cast is illegal}} |
| __extension__ int(a)++; // expected-error {{assignment to cast is illegal}} |
| __typeof(int)(a,5)<<a; // expected-error {{excess elements in scalar initializer}} |
| void(a), ++a; |
| if (int(a)+1) {} |
| for (int(a)+1;;) {} // expected-warning {{expression result unused}} |
| a = sizeof(int()+1); |
| a = sizeof(int(1)); |
| typeof(int()+1) a2; // expected-error {{extension used}} |
| (int(1)); // expected-warning {{expression result unused}} |
| |
| // type-id |
| (int())1; // expected-error {{C-style cast from 'int' to 'int ()' is not allowed}} |
| |
| // Declarations. |
| int fd(T(a)); // expected-warning {{disambiguated as a function declaration}} expected-note{{add a pair of parentheses}} |
| T(*d)(int(p)); // expected-note {{previous}} |
| typedef T td(int(p)); |
| extern T tp(int(p)); |
| T d3(); // expected-warning {{empty parentheses interpreted as a function declaration}} expected-note {{replace parentheses with an initializer}} |
| T d3v(void); |
| typedef T d3t(); |
| extern T f3(); |
| __typeof(*T()) f4(); // expected-warning {{empty parentheses interpreted as a function declaration}} expected-note {{replace parentheses with an initializer}} |
| typedef void *V; |
| __typeof(*V()) f5(); // expected-error {{ISO C++ does not allow indirection on operand of type 'V' (aka 'void *')}} |
| T multi1, |
| multi2(); // expected-warning {{empty parentheses interpreted as a function declaration}} expected-note {{replace parentheses with an initializer}} |
| T(d)[5]; // expected-error {{redefinition of 'd'}} |
| typeof(int[])(f) = { 1, 2 }; // expected-error {{extension used}} |
| void(b)(int); |
| int(d2) __attribute__(()); |
| if (int(a)=1) {} |
| int(d3(int())); |
| } |
| |
| struct RAII { |
| RAII(); |
| RAII(int); |
| ~RAII(); |
| }; |
| |
| struct NotRAII { |
| NotRAII(); |
| NotRAII(int); |
| }; |
| |
| void func(); |
| void func2(short); |
| namespace N { |
| struct S; |
| int n; |
| |
| void emptyParens() { |
| RAII raii(); // expected-warning {{function declaration}} expected-note {{remove parentheses to declare a variable}} |
| int a, b, c, d, e, // expected-note {{change this ',' to a ';' to call 'func'}} |
| func(); // expected-warning {{function declaration}} expected-note {{replace parentheses with an initializer}} |
| |
| S s(); // expected-warning {{function declaration}} |
| #if __cplusplus >= 201103L |
| // expected-note@-2 {{replace parentheses with an initializer to declare a variable}} |
| #endif |
| } |
| void nonEmptyParens() { |
| int f = 0, // g = 0; expected-note {{change this ',' to a ';' to call 'func2'}} |
| func2(short(f)); // expected-warning {{function declaration}} expected-note {{add a pair of parentheses}} |
| |
| RAII(n); // expected-warning {{parentheses were disambiguated as redundant parentheses around declaration of variable named 'n'}} |
| // expected-note@-1 {{add a variable name to declare a 'RAII' initialized with 'n'}} |
| // expected-note@-2 {{add enclosing parentheses to perform a function-style cast}} |
| // expected-note@-3 {{remove parentheses to silence this warning}} |
| |
| RAII(undeclared1); |
| #pragma clang diagnostic push |
| #pragma clang diagnostic warning "-Wredundant-parens" |
| RAII(undeclared2); // expected-warning {{redundant parentheses surrounding declarator}} |
| #pragma clang diagnostic pop |
| |
| { |
| NotRAII(n); // expected-warning {{parentheses were disambiguated as redundant parentheses around declaration of variable named 'n'}} |
| // expected-note@-1 {{add enclosing parentheses to perform a function-style cast}} |
| // expected-note@-2 {{remove parentheses to silence this warning}} |
| } |
| } |
| } |
| |
| class C { }; |
| void fn(int(C)) { } // void fn(int(*fp)(C c)) { } expected-note{{candidate function}} |
| // not: void fn(int C); |
| int g(C); |
| |
| void foo() { |
| fn(1); // expected-error {{no matching function}} |
| fn(g); // OK |
| } |
| |
| namespace PR11874 { |
| void foo(); // expected-note 3 {{class 'foo' is hidden by a non-type declaration of 'foo' here}} |
| class foo {}; |
| class bar { |
| bar() { |
| const foo* f1 = 0; // expected-error {{must use 'class' tag to refer to type 'foo' in this scope}} |
| foo* f2 = 0; // expected-error {{must use 'class' tag to refer to type 'foo' in this scope}} |
| foo f3; // expected-error {{must use 'class' tag to refer to type 'foo' in this scope}} |
| } |
| }; |
| |
| int baz; // expected-note 2 {{class 'baz' is hidden by a non-type declaration of 'baz' here}} |
| class baz {}; |
| void fizbin() { |
| const baz* b1 = 0; // expected-error {{must use 'class' tag to refer to type 'baz' in this scope}} |
| baz* b2; // expected-error {{use of undeclared identifier 'b2'}} |
| baz b3; // expected-error {{must use 'class' tag to refer to type 'baz' in this scope}} |
| } |
| } |
| |
| namespace TemporaryFromFunctionCall { |
| struct A { |
| A(int); |
| }; |
| int f(); |
| int g(int); |
| namespace N { |
| void x() { |
| // FIXME: For the first and second of these (but not the third), we |
| // should produce a vexing-parse warning. |
| A(f()); |
| A(g(int())); |
| A(g(int)); |
| } |
| } |
| } |