annotate gcc/testsuite/g++.dg/opt/pr69432.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 target/69432
kono
parents:
diff changeset
2 // { dg-do compile }
kono
parents:
diff changeset
3 // { dg-options "-O3" }
kono
parents:
diff changeset
4 // { dg-additional-options "-minline-stringops-dynamically" { target i?86-*-* x86_64-*-* } }
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 template <typename S, typename T, typename U>
kono
parents:
diff changeset
7 void
kono
parents:
diff changeset
8 f1 (S x, T y, U z)
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 for (; y; --y, ++x)
kono
parents:
diff changeset
11 *x = z;
kono
parents:
diff changeset
12 }
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 template <typename S, typename T, typename U>
kono
parents:
diff changeset
15 void f2 (S x, T y, U z)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 f1 (x, y, z);
kono
parents:
diff changeset
18 }
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 struct A {};
kono
parents:
diff changeset
21 struct B { static char f3 (A, unsigned); };
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 template <typename S, typename U>
kono
parents:
diff changeset
24 void f4 (S, U);
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 struct C
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 template <typename S, typename T, typename U>
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
29 static S f5 (S x, T y, U z) { f2 (x, y, z); return S(); }
111
kono
parents:
diff changeset
30 };
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 template <typename S, typename T, typename U>
kono
parents:
diff changeset
33 void f6 (S x, T y, U z) { C::f5 (x, y, z); }
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 template <typename S, typename T, typename U, typename V>
kono
parents:
diff changeset
36 void f7 (S x, T y, U z, V) { f6 (x, y, z); }
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 struct E
kono
parents:
diff changeset
39 {
kono
parents:
diff changeset
40 struct D : A { char e; D (A); };
kono
parents:
diff changeset
41 A f;
kono
parents:
diff changeset
42 E (int x) : g(f) { f8 (x); }
kono
parents:
diff changeset
43 ~E ();
kono
parents:
diff changeset
44 D g;
kono
parents:
diff changeset
45 void f9 (int x) { x ? B::f3 (g, x) : char (); }
kono
parents:
diff changeset
46 void f8 (int x) { f9 (x); }
kono
parents:
diff changeset
47 };
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 struct F : E
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 F (int x) : E(x) { f10 (x); f4 (this, 0); }
kono
parents:
diff changeset
52 char h;
kono
parents:
diff changeset
53 void f10 (int x) { f7 (&g.e, x, h, 0); }
kono
parents:
diff changeset
54 };
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 long a;
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 void
kono
parents:
diff changeset
59 test ()
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 F b(a);
kono
parents:
diff changeset
62 }