annotate gcc/testsuite/g++.dg/cpp0x/variadic-init.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 // { dg-do run { target c++11 } }
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 // PR c++/33510
kono
parents:
diff changeset
4 #define SIZE_FROM_CTOR
kono
parents:
diff changeset
5 extern "C" void abort ();
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 template<int M, int N> struct pair
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 int i, j;
kono
parents:
diff changeset
10 pair () : i (M), j (N) {}
kono
parents:
diff changeset
11 };
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 template<int... M> struct S
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 template<int... N> static int *foo ()
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 #ifdef SIZE_FROM_CTOR
kono
parents:
diff changeset
18 static int x[] = { (M + N)..., -1 };
kono
parents:
diff changeset
19 #else
kono
parents:
diff changeset
20 static int x[1 + sizeof... N] = { (M + N)..., -1 };
kono
parents:
diff changeset
21 #endif
kono
parents:
diff changeset
22 return x;
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24 };
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 template<typename... M> struct R
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 template<typename... N> static int *foo ()
kono
parents:
diff changeset
29 {
kono
parents:
diff changeset
30 #ifdef SIZE_FROM_CTOR
kono
parents:
diff changeset
31 static int x[] = { (sizeof(M) + sizeof(N))..., -1 };
kono
parents:
diff changeset
32 #else
kono
parents:
diff changeset
33 static int x[1 + sizeof... N] = { (sizeof(M) + sizeof(N))..., -1 };
kono
parents:
diff changeset
34 #endif
kono
parents:
diff changeset
35 return x;
kono
parents:
diff changeset
36 }
kono
parents:
diff changeset
37 };
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 int *bar ()
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 return S<0, 1, 2>::foo<0, 1, 2> ();
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 int *baz ()
kono
parents:
diff changeset
45 {
kono
parents:
diff changeset
46 return R<char, short, int>::foo<float, double, long> ();
kono
parents:
diff changeset
47 }
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 int main ()
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 int *p = bar ();
kono
parents:
diff changeset
53 if (p[0] != 0 || p[1] != 2 || p[2] != 4 || p[3] != -1)
kono
parents:
diff changeset
54 abort ();
kono
parents:
diff changeset
55 }