ast-print.c
3.54 KB
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
// RUN: %clang_cc1 %s -ast-print -verify > %t.c
// RUN: FileCheck %s --input-file %t.c
//
// RUN: echo >> %t.c "// expected""-warning@* {{use of GNU old-style field designator extension}}"
// RUN: echo >> %t.c "// expected""-warning@* {{'EnumWithAttributes' is deprecated}}"
// RUN: echo >> %t.c "// expected""-note@* {{'EnumWithAttributes' has been explicitly marked deprecated here}}"
// RUN: echo >> %t.c "// expected""-warning@* {{'EnumWithAttributes2' is deprecated}}"
// RUN: echo >> %t.c "// expected""-note@* {{'EnumWithAttributes2' has been explicitly marked deprecated here}}"
// RUN: echo >> %t.c "// expected""-warning@* {{'EnumWithAttributes3' is deprecated}}"
// RUN: echo >> %t.c "// expected""-note@* {{'EnumWithAttributes3' has been explicitly marked deprecated here}}"
// RUN: %clang_cc1 -fsyntax-only %t.c -verify
typedef void func_typedef();
func_typedef xxx;
typedef void func_t(int x);
func_t a;
struct blah {
struct {
struct {
int b;
};
};
};
// This used to crash clang.
struct {
}(s1);
int foo(const struct blah *b) {
// CHECK: return b->b;
return b->b;
}
int arr(int a[static 3]) {
// CHECK: int a[static 3]
return a[2];
}
int rarr(int a[restrict static 3]) {
// CHECK: int a[restrict static 3]
return a[2];
}
int varr(int n, int a[static n]) {
// CHECK: int a[static n]
return a[2];
}
int rvarr(int n, int a[restrict static n]) {
// CHECK: int a[restrict static n]
return a[2];
}
// CHECK: typedef struct {
typedef struct {
int f;
} T __attribute__ ((__aligned__));
// CHECK: struct __attribute__((visibility("default"))) S;
struct __attribute__((visibility("default"))) S;
struct pair_t {
int a;
int b;
};
// CHECK: struct pair_t p = {a: 3, .b = 4};
struct pair_t p = {a: 3, .b = 4}; // expected-warning {{use of GNU old-style field designator extension}}
void initializers() {
// CHECK: int *x = ((void *)0), *y = ((void *)0);
int *x = ((void *)0), *y = ((void *)0);
struct Z{};
struct {
struct Z z;
// CHECK: } z = {(struct Z){}};
} z = {(struct Z){}};
}
// CHECK-LABEL: enum __attribute__((deprecated(""))) EnumWithAttributes {
enum EnumWithAttributes { // expected-warning {{'EnumWithAttributes' is deprecated}}
// CHECK-NEXT: EnumWithAttributesFoo __attribute__((deprecated(""))),
EnumWithAttributesFoo __attribute__((deprecated)),
// CHECK-NEXT: EnumWithAttributesBar __attribute__((unavailable(""))) = 50
EnumWithAttributesBar __attribute__((unavailable)) = 50
// CHECK-NEXT: } *EnumWithAttributesPtr;
} __attribute__((deprecated)) *EnumWithAttributesPtr; // expected-note {{'EnumWithAttributes' has been explicitly marked deprecated here}}
// CHECK-LABEL: enum __attribute__((deprecated(""))) EnumWithAttributes2 *EnumWithAttributes2Ptr;
// expected-warning@+2 {{'EnumWithAttributes2' is deprecated}}
// expected-note@+1 {{'EnumWithAttributes2' has been explicitly marked deprecated here}}
enum __attribute__((deprecated)) EnumWithAttributes2 *EnumWithAttributes2Ptr;
// CHECK-LABEL: EnumWithAttributes3Fn
void EnumWithAttributes3Fn() {
// CHECK-NEXT: enum __attribute__((deprecated(""))) EnumWithAttributes3 *EnumWithAttributes3Ptr;
// expected-warning@+2 {{'EnumWithAttributes3' is deprecated}}
// expected-note@+1 {{'EnumWithAttributes3' has been explicitly marked deprecated here}}
enum __attribute__((deprecated)) EnumWithAttributes3 *EnumWithAttributes3Ptr;
// Printing must not put the attribute after the tag where it would apply to
// the variable instead of the type, and then our deprecation warning would
// move to this use of the variable.
void *p = EnumWithAttributes3Ptr;
}