annotate gcc/testsuite/g++.dg/cpp1y/constexpr-array2.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // PR c++/69261
kono
parents:
diff changeset
2 // { dg-do run { target c++14 } }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 typedef __SIZE_TYPE__ size_t;
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 template <size_t N>
kono
parents:
diff changeset
7 struct S
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 constexpr S() = default;
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 template<size_t M>
kono
parents:
diff changeset
12 constexpr S (char const (&d)[M]) : data { 0 }
kono
parents:
diff changeset
13 {
kono
parents:
diff changeset
14 static_assert (M <= N, "size!");
kono
parents:
diff changeset
15 for (size_t i = 0; i != M; i++)
kono
parents:
diff changeset
16 data[i] = d[i];
kono
parents:
diff changeset
17 }
kono
parents:
diff changeset
18 char data[N];
kono
parents:
diff changeset
19 };
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 template <int N>
kono
parents:
diff changeset
22 constexpr S<N>
kono
parents:
diff changeset
23 s (char const (&d)[N])
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 S<N> c {};
kono
parents:
diff changeset
26 for (size_t i = 0; i != N; i++)
kono
parents:
diff changeset
27 c.data[i] = d[i];
kono
parents:
diff changeset
28 return c;
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 template <size_t N, size_t M>
kono
parents:
diff changeset
32 constexpr auto
kono
parents:
diff changeset
33 concat (S<N> const& s1, S<M> const& s2)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 S<N+M-1> s (s1.data);
kono
parents:
diff changeset
36 for (size_t i = 0; i != M; i++)
kono
parents:
diff changeset
37 s.data[N + i - 1] = s2.data[i];
kono
parents:
diff changeset
38 return s;
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 template <size_t N, size_t M>
kono
parents:
diff changeset
42 constexpr auto
kono
parents:
diff changeset
43 concat (char const (&x)[N], char const (&y)[M])
kono
parents:
diff changeset
44 {
kono
parents:
diff changeset
45 S<N+M-1> tmp { x };
kono
parents:
diff changeset
46 for (size_t i = 0; i != M; i++)
kono
parents:
diff changeset
47 tmp.data[N+i-1] = y[i];
kono
parents:
diff changeset
48 return tmp;
kono
parents:
diff changeset
49 }
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 int
kono
parents:
diff changeset
52 main ()
kono
parents:
diff changeset
53 {
kono
parents:
diff changeset
54 auto constexpr s1 = s ("bla");
kono
parents:
diff changeset
55 auto constexpr s2 = s ("blub");
kono
parents:
diff changeset
56 S<8> constexpr s1s2 = concat (s1, s2);
kono
parents:
diff changeset
57 auto constexpr c = concat ("bla", "blub");
kono
parents:
diff changeset
58 if (__builtin_strcmp (s1.data, "bla")
kono
parents:
diff changeset
59 || __builtin_strcmp (s2.data, "blub")
kono
parents:
diff changeset
60 || __builtin_strcmp (s1s2.data, "blablub")
kono
parents:
diff changeset
61 || __builtin_strcmp (c.data, "blablub"))
kono
parents:
diff changeset
62 __builtin_abort ();
kono
parents:
diff changeset
63 }