/* Contributed by Kris Van Hees */ /* Test incremental initializers for char16_t/char32_t arrays. */ /* { dg-do run { target int32plus } } */ /* { dg-options "-std=gnu99" } */ typedef __SIZE_TYPE__ size_t; typedef __CHAR16_TYPE__ char16_t; typedef __CHAR32_TYPE__ char32_t; extern int memcmp (const void *, const void *, size_t); extern void abort (void); extern void exit (int); struct A { char16_t S[6]; int M; } a[] = { { { u"foo" }, 1 }, [0].S[2] = u'x', [0].S[4] = u'y' }; struct A b[] = { { { u"foo" }, 1 }, [0] = { .S[0] = u'b' } }; struct A c[] = { { { u"foo" }, 1 }, [0].S = { u"a" }, [0].M = 2 }; struct B { char32_t S[6]; int M; } d[] = { { { U"foo" }, 1 }, [0].S[2] = U'x', [0].S[4] = U'y' }; struct B e[] = { { { U"foo" }, 1 }, [0] = { .S[0] = U'b' } }; struct B f[] = { { { U"foo" }, 1 }, [0].S = { U"a" }, [0].M = 2 }; int main (void) { if (memcmp (a[0].S, u"fox\0y", 6 * sizeof(char16_t)) || a[0].M != 1) abort (); if (memcmp (b[0].S, u"b\0\0\0\0", 6) || b[0].M) abort (); if (memcmp (c[0].S, u"a\0\0\0\0", 6) || c[0].M != 2) abort (); if (memcmp (d[0].S, U"fox\0y", 6 * sizeof(char32_t)) || d[0].M != 1) abort (); if (memcmp (e[0].S, U"b\0\0\0\0", 6) || e[0].M) abort (); if (memcmp (f[0].S, U"a\0\0\0\0", 6) || f[0].M != 2) abort (); exit(0); }