| // RUN: %clang_cc1 -fsyntax-only -pedantic -verify %s |
| |
| void f() { |
| typedef int T; |
| int x, *px; |
| |
| // Type id. |
| (T())x; // expected-error {{cast from 'int' to 'T ()'}} |
| (T())+x; // expected-error {{cast from 'int' to 'T ()'}} |
| (T())*px; // expected-error {{cast from 'int' to 'T ()'}} |
| |
| // Expression. |
| x = (T()); |
| x = (T())/x; |
| |
| typedef int *PT; |
| // Make sure stuff inside the parens are parsed only once (only one warning). |
| x = (PT()[(int){1}]); // expected-warning {{compound literals}} |
| |
| // Special case: empty parens is a call, not an expression |
| struct S{int operator()();}; |
| (S())(); |
| |
| // Special case: "++" is postfix here, not prefix |
| (S())++; // expected-error {{cannot increment value of type 'S'}} |
| |
| struct X { int &operator++(int); X operator[](int); int &operator++(); }; |
| int &postfix_incr = (X()[3])++; |
| (X())++ ++; // ok, not a C-style cast |
| (X())++ ++X(); // expected-error {{C-style cast from 'int' to 'X ()'}} |
| int q = (int)++(x); |
| } |
| |
| // Make sure we do tentative parsing correctly in conditions. |
| typedef int type; |
| struct rec { rec(int); }; |
| |
| namespace ns { |
| typedef int type; |
| struct rec { rec(int); }; |
| } |
| |
| struct cls { |
| typedef int type; |
| struct rec { rec(int); }; |
| }; |
| |
| struct result { |
| template <class T> result(T); |
| bool check(); |
| }; |
| |
| void test(int i) { |
| if (result((cls::type) i).check()) |
| return; |
| |
| if (result((ns::type) i).check()) |
| return; |
| |
| if (result((::type) i).check()) |
| return; |
| |
| if (result((cls::rec) i).check()) |
| return; |
| |
| if (result((ns::rec) i).check()) |
| return; |
| |
| if (result((::rec) i).check()) |
| return; |
| } |
| |