lin
2025-08-21 57113df3a0e2be01232281fad9a5f2c060567981
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
// 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;
}