280 lines
6.4 KiB
C
280 lines
6.4 KiB
C
|
// RUN: %clang_cc1 -fsyntax-only -verify -triple x86_64-unknown-unknown %s
|
||
|
|
||
|
int complete_array_from_init[] = { 1, 2, [10] = 5, 1, 2, [5] = 2, 6 };
|
||
|
|
||
|
int complete_array_from_init_check[((sizeof(complete_array_from_init) / sizeof(int)) == 13)? 1 : -1];
|
||
|
|
||
|
int iarray[10] = {
|
||
|
[0] = 1,
|
||
|
[1 ... 5] = 2,
|
||
|
[ 6 ... 6 ] = 3,
|
||
|
[ 8 ... 7 ] = 4, // expected-error{{array designator range [8, 7] is empty}}
|
||
|
[10] = 5,
|
||
|
[-1] = 6 // expected-error{{array designator value '-1' is negative}}
|
||
|
};
|
||
|
|
||
|
int iarray2[10] = {
|
||
|
[10] = 1, // expected-error{{array designator index (10) exceeds array bounds (10)}}
|
||
|
};
|
||
|
|
||
|
int iarray3[10] = {
|
||
|
[3] 2, // expected-warning{{use of GNU 'missing =' extension in designator}}
|
||
|
[5 ... 12] = 2 // expected-error{{array designator index (12) exceeds array bounds (10)}}
|
||
|
};
|
||
|
|
||
|
struct point {
|
||
|
double x;
|
||
|
double y;
|
||
|
};
|
||
|
|
||
|
struct point p1 = {
|
||
|
.y = 1.0,
|
||
|
x: 2.0, // expected-warning{{}}
|
||
|
.a = 4.0, // expected-error{{field designator 'a' does not refer to any field in type 'struct point'}}
|
||
|
};
|
||
|
|
||
|
struct point p2 = {
|
||
|
[1] = 1.0 // expected-error{{array designator cannot initialize non-array type}}
|
||
|
};
|
||
|
|
||
|
struct point array[10] = {
|
||
|
[0].x = 1.0,
|
||
|
[1].y = 2.0,
|
||
|
[2].z = 3.0, // expected-error{{field designator 'z' does not refer to any field in type 'struct point'}}
|
||
|
};
|
||
|
|
||
|
struct point array2[10] = {
|
||
|
[10].x = 2.0, // expected-error{{array designator index (10) exceeds array bounds (10)}}
|
||
|
[4 ... 5].y = 2.0,
|
||
|
[4 ... 6] = { .x = 3, .y = 4.0 }
|
||
|
};
|
||
|
|
||
|
struct point array3[10] = {
|
||
|
.x = 5 // expected-error{{field designator cannot initialize a non-struct, non-union type}}
|
||
|
};
|
||
|
|
||
|
struct rect {
|
||
|
struct point top_left;
|
||
|
struct point bottom_right;
|
||
|
};
|
||
|
|
||
|
struct rect window = { .top_left.x = 1.0 };
|
||
|
|
||
|
struct rect windows[] = {
|
||
|
[2].top_left = { 1.0, 2.0 },
|
||
|
[4].bottom_right = { .y = 1.0 },
|
||
|
{ { .y = 7.0, .x = 8.0 }, { .x = 5.0 } },
|
||
|
[3] = { .top_left = { 1.1, 2.2 }, .bottom_right = { .y = 1.1 } }
|
||
|
};
|
||
|
|
||
|
int windows_size[((sizeof(windows) / sizeof(struct rect)) == 6)? 1 : -1];
|
||
|
|
||
|
struct rect windows_bad[3] = {
|
||
|
[2].top_left = { { .x = 1.1 } }, // expected-error{{designator in initializer for scalar type}}
|
||
|
[1].top_left = { .x = 1.1 }
|
||
|
};
|
||
|
|
||
|
struct gui {
|
||
|
struct rect windows[10];
|
||
|
};
|
||
|
|
||
|
struct gui gui[] = {
|
||
|
[5].windows[3].top_left.x = { 7.0 } // expected-warning{{braces around scalar initializer}}
|
||
|
};
|
||
|
|
||
|
struct translator {
|
||
|
struct wonky { int * ptr; } wonky ;
|
||
|
struct rect window;
|
||
|
struct point offset;
|
||
|
} tran = {
|
||
|
.window = { .top_left = { 1.0, 2.0 } },
|
||
|
{ .x = 5.0, .y = 6.0 },
|
||
|
.wonky = { 0 }
|
||
|
};
|
||
|
|
||
|
int anint;
|
||
|
struct {int x,*y;} z[] = {[0].x = 2, &z[0].x};
|
||
|
|
||
|
struct outer { struct inner { int x, *y; } in, *inp; } zz[] = {
|
||
|
[0].in.x = 2, &zz[0].in.x, &zz[0].in,
|
||
|
0, &anint, &zz[1].in,
|
||
|
[3].in = { .y = &anint, .x = 17 },
|
||
|
[7].in.y = &anint, &zz[0].in,
|
||
|
[4].in.y = &anint, [5].in.x = 12
|
||
|
};
|
||
|
|
||
|
int zz_sizecheck[sizeof(zz) / sizeof(struct outer) == 8? 1 : -1 ];
|
||
|
|
||
|
struct disklabel_ops {
|
||
|
struct {} type;
|
||
|
int labelsize;
|
||
|
};
|
||
|
|
||
|
struct disklabel_ops disklabel64_ops = {
|
||
|
.labelsize = sizeof(struct disklabel_ops)
|
||
|
};
|
||
|
|
||
|
// PR clang/3378
|
||
|
int bitwidth[] = { [(long long int)1] = 5, [(short int)2] = 2 };
|
||
|
int a[]= { [sizeof(int)] = 0 };
|
||
|
int a2[]= { [0 ... sizeof(int)] = 0 };
|
||
|
|
||
|
// Test warnings about initializers overriding previous initializers
|
||
|
struct X {
|
||
|
int a, b, c;
|
||
|
};
|
||
|
|
||
|
int counter = 0;
|
||
|
int get8() { ++counter; return 8; }
|
||
|
|
||
|
void test() {
|
||
|
struct X xs[] = {
|
||
|
[0] = (struct X){1, 2}, // expected-note{{previous initialization is here}}
|
||
|
[0].c = 3, // expected-warning{{subobject initialization overrides initialization of other fields within its enclosing subobject}}
|
||
|
(struct X) {4, 5, 6}, // expected-note{{previous initialization is here}}
|
||
|
[1].b = get8(), // expected-warning{{subobject initialization overrides initialization of other fields within its enclosing subobject}}
|
||
|
[0].b = 8
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// FIXME: How do we test that this initializes the long properly?
|
||
|
union { char c; long l; } u1 = { .l = 0xFFFF };
|
||
|
|
||
|
extern float global_float;
|
||
|
|
||
|
struct XX { int a, *b; };
|
||
|
struct XY { int before; struct XX xx, *xp; float* after; } xy[] = {
|
||
|
0, 0, &xy[0].xx.a, &xy[0].xx, &global_float,
|
||
|
[1].xx = 0, &xy[1].xx.a, &xy[1].xx, &global_float,
|
||
|
0, // expected-note{{previous initialization is here}}
|
||
|
0, // expected-note{{previous initialization is here}}
|
||
|
[2].before = 0, // expected-warning{{initializer overrides prior initialization of this subobject}}
|
||
|
0, // expected-warning{{initializer overrides prior initialization of this subobject}}
|
||
|
&xy[2].xx.a, &xy[2].xx, &global_float
|
||
|
};
|
||
|
|
||
|
// PR3519
|
||
|
struct foo {
|
||
|
int arr[10];
|
||
|
};
|
||
|
|
||
|
struct foo Y[10] = {
|
||
|
[1] .arr [1] = 2,
|
||
|
[4] .arr [2] = 4
|
||
|
};
|
||
|
|
||
|
struct bar {
|
||
|
struct foo f;
|
||
|
float *arr[10];
|
||
|
};
|
||
|
|
||
|
extern float f;
|
||
|
struct bar saloon = {
|
||
|
.f.arr[3] = 1,
|
||
|
.arr = { &f }
|
||
|
};
|
||
|
|
||
|
typedef unsigned char u_char;
|
||
|
typedef unsigned short u_short;
|
||
|
|
||
|
union wibble {
|
||
|
u_char arr1[6];
|
||
|
u_short arr2[3];
|
||
|
};
|
||
|
|
||
|
const union wibble wobble = { .arr2[0] = 0xffff,
|
||
|
.arr2[1] = 0xffff,
|
||
|
.arr2[2] = 0xffff };
|
||
|
|
||
|
const union wibble wobble2 = { .arr2 = {4, 5, 6}, 7 }; // expected-warning{{excess elements in union initializer}}
|
||
|
|
||
|
// PR3778
|
||
|
struct s {
|
||
|
union { int i; };
|
||
|
};
|
||
|
struct s si = {
|
||
|
{ .i = 1 }
|
||
|
};
|
||
|
|
||
|
double d0;
|
||
|
char c0;
|
||
|
float f0;
|
||
|
int i0;
|
||
|
|
||
|
struct Enigma {
|
||
|
union {
|
||
|
struct {
|
||
|
struct {
|
||
|
double *double_ptr;
|
||
|
char *string;
|
||
|
};
|
||
|
float *float_ptr;
|
||
|
};
|
||
|
int *int_ptr;
|
||
|
};
|
||
|
char *string2;
|
||
|
};
|
||
|
|
||
|
struct Enigma enigma = {
|
||
|
.double_ptr = &d0, &c0,
|
||
|
&f0, // expected-note{{previous}}
|
||
|
&c0,
|
||
|
.float_ptr = &f0 // expected-warning{{overrides}}
|
||
|
};
|
||
|
|
||
|
|
||
|
/// PR4073
|
||
|
/// Should use evaluate to fold aggressively and emit a warning if not an ice.
|
||
|
extern int crazy_x;
|
||
|
|
||
|
int crazy_Y[] = {
|
||
|
[ 0 ? crazy_x : 4] = 1
|
||
|
};
|
||
|
|
||
|
// PR5843
|
||
|
struct expr {
|
||
|
int nargs;
|
||
|
union {
|
||
|
unsigned long int num;
|
||
|
struct expr *args[3];
|
||
|
} val;
|
||
|
};
|
||
|
|
||
|
struct expr expr0 = {
|
||
|
.nargs = 2,
|
||
|
.val = {
|
||
|
.args = {
|
||
|
[0] = (struct expr *)0,
|
||
|
[1] = (struct expr *)0
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
|
||
|
// PR6955
|
||
|
|
||
|
struct ds {
|
||
|
struct {
|
||
|
struct {
|
||
|
unsigned int a;
|
||
|
};
|
||
|
unsigned int b;
|
||
|
struct {
|
||
|
unsigned int c;
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
// C1X lookup-based anonymous member init cases
|
||
|
struct ds ds0 = {
|
||
|
{ {
|
||
|
.a = 1 // expected-note{{previous initialization is here}}
|
||
|
} },
|
||
|
.a = 2, // expected-warning{{initializer overrides prior initialization of this subobject}}
|
||
|
.b = 3
|
||
|
};
|
||
|
struct ds ds1 = { .c = 0 };
|
||
|
struct ds ds2 = { { {
|
||
|
.a = 0,
|
||
|
.b = 1 // expected-error{{field designator 'b' does not refer to any field}}
|
||
|
} } };
|