aboutsummaryrefslogtreecommitdiffstats
path: root/test/regression/initializers3.c
diff options
context:
space:
mode:
authorXavier Leroy <xavierleroy@users.noreply.github.com>2018-03-30 19:07:54 +0200
committerGitHub <noreply@github.com>2018-03-30 19:07:54 +0200
commit1ee8c15657cddca0d0727865327ba154b9df45d5 (patch)
treeb823c553f511253e7af83b639820c284098a5f97 /test/regression/initializers3.c
parent6b1463c4de3ae182fac6b5f2d15248d87c2f9613 (diff)
downloadcompcert-kvx-1ee8c15657cddca0d0727865327ba154b9df45d5.tar.gz
compcert-kvx-1ee8c15657cddca0d0727865327ba154b9df45d5.zip
Turn delicate case of designated re-initialization into error (#70)
Consider: struct P { int x, y; } struct S { struct P p; } struct P p0 = { 1,2 }; struct S s1 = { .p = p0; .p.x = 3 }; ISO C99 and recent versions of Clang initialize s1.p.y to 2, i.e. the initialization of s1.p.y to p0.y implied by ".p = p0" is kept, even though the initialization of s1.p.x to p0.x is overwritten by ".p.x = 3". GCC, old versions of Clang, and previous versions of CompCert initialize s1.p.y to the default value 0. I.e. the initialization ".p = p0" is forgotten, leaving default values for the fields of .p before ".p.x = 3" takes effect. Implementing the proper ISO C99 semantics in CompCert is difficult, owing to a mismatch between the intended semantics and the C.init representation of initializers. This commit turns the delicate case of reinitialization above (re-initializing a member of a composite that has already been initialized as a whole) into a compile-time error. We will then see if the delicate case occurs in practice and needs further attention.
Diffstat (limited to 'test/regression/initializers3.c')
-rw-r--r--test/regression/initializers3.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/test/regression/initializers3.c b/test/regression/initializers3.c
index 359a0f71..0769facc 100644
--- a/test/regression/initializers3.c
+++ b/test/regression/initializers3.c
@@ -82,8 +82,14 @@ int main()
print_S("s1", &s1);
struct S s2 = { .a.y = 1, .u.c[4] = 'x', .u.b = p1 };
print_S("s2", &s2);
+ /* ISO C99 and recent Clang say s3.a.y = 77
+ GCC and earlier CompCert versions say s3.a.y = 0
+ Now CompCert fails on an error "unsupported reinitialization". */
+#if 0
struct S s3 = { .tag = 1, .a = p1, .a.x = 1, .u.c = "Hello!", .u.c[7] = 'X' };
print_S("s3", &s3);
+#endif
+ /* This other reinitialization is correctly supported, though. */
struct S s4 = { .tag = 0, .a.x = 1, .a = p1, .u.b = 88, 99 };
print_S("s4", &s4);
return 0;