annotate gcc/testsuite/g++.dg/opt/nrv15.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 debug/39086
kono
parents:
diff changeset
2 // { dg-options "-g -O -fno-tree-sra" }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 struct A { int v; };
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 A ax;
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 struct B
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 static A f1 () { return ax; }
kono
parents:
diff changeset
11 static bool f2 ();
kono
parents:
diff changeset
12 static A f3 ();
kono
parents:
diff changeset
13 };
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 struct C
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 A f4 ()
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 A x;
kono
parents:
diff changeset
20 if (__builtin_expect (this->f6 () < this->f12 (), true))
kono
parents:
diff changeset
21 x = B::f1 ();
kono
parents:
diff changeset
22 else
kono
parents:
diff changeset
23 x = this->f7 ();
kono
parents:
diff changeset
24 return x;
kono
parents:
diff changeset
25 }
kono
parents:
diff changeset
26 A f5 ()
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 A y;
kono
parents:
diff changeset
29 if (this->f6 () < this->f12 ())
kono
parents:
diff changeset
30 y = B::f1 ();
kono
parents:
diff changeset
31 else
kono
parents:
diff changeset
32 y = this->f7 ();
kono
parents:
diff changeset
33 return y;
kono
parents:
diff changeset
34 }
kono
parents:
diff changeset
35 void *f6 () const;
kono
parents:
diff changeset
36 void *f12 () const;
kono
parents:
diff changeset
37 virtual A f7 ();
kono
parents:
diff changeset
38 };
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 C *dx;
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 struct D
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 C *f8 () const;
kono
parents:
diff changeset
45 };
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 class E : virtual public D
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 void f11 ();
kono
parents:
diff changeset
50 void f9 ();
kono
parents:
diff changeset
51 void f10 ();
kono
parents:
diff changeset
52 };
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 struct G
kono
parents:
diff changeset
55 {
kono
parents:
diff changeset
56 explicit G ();
kono
parents:
diff changeset
57 operator bool () const;
kono
parents:
diff changeset
58 };
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 void
kono
parents:
diff changeset
61 E::f11 (void)
kono
parents:
diff changeset
62 {
kono
parents:
diff changeset
63 A d = B::f3 ();
kono
parents:
diff changeset
64 d = this->f8 ()->f4 ();
kono
parents:
diff changeset
65 }
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 void
kono
parents:
diff changeset
68 E::f9 ()
kono
parents:
diff changeset
69 {
kono
parents:
diff changeset
70 G c;
kono
parents:
diff changeset
71 if (c)
kono
parents:
diff changeset
72 {
kono
parents:
diff changeset
73 const A e = B::f3 ();
kono
parents:
diff changeset
74 C * f = this->f8 ();
kono
parents:
diff changeset
75 A d = f->f5 ();
kono
parents:
diff changeset
76 if (B::f2 ())
kono
parents:
diff changeset
77 ;
kono
parents:
diff changeset
78 else if (B::f2 ())
kono
parents:
diff changeset
79 f->f4 ();
kono
parents:
diff changeset
80 }
kono
parents:
diff changeset
81 }
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 void
kono
parents:
diff changeset
84 E::f10 ()
kono
parents:
diff changeset
85 {
kono
parents:
diff changeset
86 G c;
kono
parents:
diff changeset
87 if (c)
kono
parents:
diff changeset
88 {
kono
parents:
diff changeset
89 const A e = B::f3 ();
kono
parents:
diff changeset
90 C * f = this->f8 ();
kono
parents:
diff changeset
91 A d = f->f5 ();
kono
parents:
diff changeset
92 if (B::f2 ())
kono
parents:
diff changeset
93 ;
kono
parents:
diff changeset
94 else if (B::f2 ())
kono
parents:
diff changeset
95 f->f4 ();
kono
parents:
diff changeset
96 }
kono
parents:
diff changeset
97 }