1 // RUN: %clang_cc1 -fsyntax-only -pedantic -verify %s 2 3 /* This test checks the introduction of struct and union types based 4 on a type specifier of the form "struct-or-union identifier" when they 5 type has not yet been declared. See C99 6.7.2.3p8. */ 6 7 typedef struct S1 { 8 union { 9 struct S2 *x; 10 struct S3 *y; 11 } u1; 12 } S1; 13 14 int test_struct_scope(S1 *s1, struct S2 *s2, struct S3 *s3) { 15 if (s1->u1.x == s2) return 1; 16 if (s1->u1.y == s3) return 1; 17 return 0; 18 } 19 20 int test_struct_scope_2(S1 *s1) { 21 struct S2 { int x; } *s2 = 0; 22 if (s1->u1.x == s2) return 1; /* expected-warning {{comparison of distinct pointer types ('struct S2 *' and 'struct S2 *')}} */ 23 return 0; 24 } 25 26 // FIXME: We do not properly implement C99 6.2.1p4, which says that 27 // the type "struct S4" declared in the function parameter list has 28 // block scope within the function definition. The problem, in this 29 // case, is that the code is ill-formed but we warn about the two S4's 30 // being incompatible (we think they are two different types). 31 int test_struct_scope_3(struct S4 * s4) { // expected-warning{{declaration of 'struct S4' will not be visible outside of this function}} 32 struct S4 { int y; } *s4_2 = 0; 33 /* if (s4 == s4_2) return 1; */ 34 return 0; 35 } 36 37 void f(struct S5 { int y; } s5); // expected-warning{{declaration of 'struct S5' will not be visible outside of this function}} 38 39 // PR clang/3312 40 struct S6 { 41 enum { BAR } e; 42 }; 43 44 void test_S6() { 45 struct S6 a; 46 a.e = BAR; 47 } 48 49 // <rdar://problem/6487669> 50 typedef struct z_foo_s { 51 struct bar_baz *baz; 52 } z_foo; 53 typedef z_foo *z_foop; 54 struct bar_baz { 55 enum { 56 SQUAT, FLAG, DICT4, DICT3, DICT2, DICT1, DICT0, HOP, CHECK4, CHECK3, CHECK2, CHECK1, DONE, BAD 57 } mode; 58 int nowrap; 59 }; 60 void 61 wizbiz_quxPoof(z) 62 z_foop z; 63 { 64 z->baz->mode = z->baz->nowrap ? HOP : SQUAT; 65 } 66