diff options
Diffstat (limited to 'test/CodeGen/designated-initializers.c')
-rw-r--r-- | test/CodeGen/designated-initializers.c | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/test/CodeGen/designated-initializers.c b/test/CodeGen/designated-initializers.c index 6561ce5..b11c67a 100644 --- a/test/CodeGen/designated-initializers.c +++ b/test/CodeGen/designated-initializers.c @@ -52,6 +52,93 @@ struct ds ds7 = { .b = 3 }; + +// <rdar://problem/10465114> +struct overwrite_string_struct1 { + __typeof(L"foo"[0]) L[6]; + int M; +} overwrite_string1[] = { { { L"foo" }, 1 }, [0].L[2] = L'x'}; +// CHECK: [6 x i32] [i32 102, i32 111, i32 120, i32 0, i32 0, i32 0], i32 1 +struct overwrite_string_struct2 { + char L[6]; + int M; +} overwrite_string2[] = { { { "foo" }, 1 }, [0].L[2] = 'x'}; +// CHECK: [6 x i8] c"fox\00\00\00", i32 1 +struct overwrite_string_struct3 { + char L[3]; + int M; +} overwrite_string3[] = { { { "foo" }, 1 }, [0].L[2] = 'x'}; +// CHECK: [3 x i8] c"fox", i32 1 +struct overwrite_string_struct4 { + char L[3]; + int M; +} overwrite_string4[] = { { { "foobar" }, 1 }, [0].L[2] = 'x'}; +// CHECK: [3 x i8] c"fox", i32 1 +struct overwrite_string_struct5 { + char L[6]; + int M; +} overwrite_string5[] = { { { "foo" }, 1 }, [0].L[4] = 'y'}; +// CHECK: [6 x i8] c"foo\00y\00", i32 1 + + +// CHECK: @u1 = {{.*}} { i32 65535 } +union u_FFFF { char c; long l; } u1 = { .l = 0xFFFF }; + + +/// PR16644 +typedef union u_16644 { + struct s_16644 { + int zero; + int one; + int two; + int three; + } a; + int b[4]; +} union_16644_t; + +// CHECK: @union_16644_instance_0 = {{.*}} { i32 0, i32 0, i32 0, i32 3 } } +union_16644_t union_16644_instance_0 = +{ + .b[0] = 0, + .a.one = 1, + .b[2] = 2, + .a.three = 3, +}; + +// CHECK: @union_16644_instance_1 = {{.*}} [i32 10, i32 0, i32 0, i32 0] +union_16644_t union_16644_instance_1 = +{ + .a.three = 13, + .b[2] = 12, + .a.one = 11, + .b[0] = 10, +}; + +// CHECK: @union_16644_instance_2 = {{.*}} [i32 0, i32 20, i32 0, i32 0] +union_16644_t union_16644_instance_2 = +{ + .a.one = 21, + .b[1] = 20, +}; + +// CHECK: @union_16644_instance_3 = {{.*}} { i32 0, i32 31, i32 0, i32 0 } +union_16644_t union_16644_instance_3 = +{ + .b[1] = 30, + .a = { + .one = 31 + } +}; + +// CHECK: @union_16644_instance_4 = {{.*}} { i32 5, i32 2, i32 0, i32 0 } {{.*}} [i32 0, i32 4, i32 0, i32 0] +union_16644_t union_16644_instance_4[2] = +{ + [0].a.one = 2, + [1].a.zero = 3, + [0].a.zero = 5, + [1].b[1] = 4 +}; + void test1(int argc, char **argv) { // CHECK: internal global %struct.foo { i8* null, i32 1024 } |