annotate gcc/testsuite/g++.dg/torture/pr64282.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 compile }
kono
parents:
diff changeset
2 template <class _T1> struct A
kono
parents:
diff changeset
3 {
kono
parents:
diff changeset
4 _T1 first;
kono
parents:
diff changeset
5 };
kono
parents:
diff changeset
6 struct B
kono
parents:
diff changeset
7 {
kono
parents:
diff changeset
8 int operator!=(B);
kono
parents:
diff changeset
9 };
kono
parents:
diff changeset
10 template <typename _Tp> struct C
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 C (B);
kono
parents:
diff changeset
13 _Tp operator*();
kono
parents:
diff changeset
14 int operator!=(C);
kono
parents:
diff changeset
15 };
kono
parents:
diff changeset
16 template <typename _Tp> class D
kono
parents:
diff changeset
17 {
kono
parents:
diff changeset
18 public:
kono
parents:
diff changeset
19 typedef C<_Tp> const_iterator;
kono
parents:
diff changeset
20 const_iterator m_fn1 () const;
kono
parents:
diff changeset
21 B m_fn2 ();
kono
parents:
diff changeset
22 void m_fn3 ();
kono
parents:
diff changeset
23 };
kono
parents:
diff changeset
24 class F
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 struct G
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 static G &
kono
parents:
diff changeset
29 m_fn5 ()
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 void fn1 ();
kono
parents:
diff changeset
32 return *reinterpret_cast<G *> (fn1);
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34 int *
kono
parents:
diff changeset
35 m_fn6 ()
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 return reinterpret_cast<int *> (this);
kono
parents:
diff changeset
38 }
kono
parents:
diff changeset
39 };
kono
parents:
diff changeset
40 struct _Alloc_hider
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 _Alloc_hider (int *p1, int) : _M_p (p1) {}
kono
parents:
diff changeset
43 int *_M_p;
kono
parents:
diff changeset
44 } _M_dataplus;
kono
parents:
diff changeset
45 G &
kono
parents:
diff changeset
46 m_fn4 ()
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 return G::m_fn5 ();
kono
parents:
diff changeset
49 }
kono
parents:
diff changeset
50 public:
kono
parents:
diff changeset
51 F () : _M_dataplus (m_fn4 ().m_fn6 (), 0) {}
kono
parents:
diff changeset
52 };
kono
parents:
diff changeset
53 class H
kono
parents:
diff changeset
54 {
kono
parents:
diff changeset
55 void m_fn7 (const F &, bool &);
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
56 void m_fn8 (const D<F> &, const F &, F &);
111
kono
parents:
diff changeset
57 };
kono
parents:
diff changeset
58 typedef A<int> CandPair;
kono
parents:
diff changeset
59 class I
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 public:
kono
parents:
diff changeset
62 virtual void m_fn9 (const F &, bool, D<CandPair> &);
kono
parents:
diff changeset
63 };
kono
parents:
diff changeset
64 class J : I
kono
parents:
diff changeset
65 {
kono
parents:
diff changeset
66 public:
kono
parents:
diff changeset
67 void m_fn9 (const F &, bool, D<CandPair> &);
kono
parents:
diff changeset
68 };
kono
parents:
diff changeset
69 D<I *> c;
kono
parents:
diff changeset
70 void
kono
parents:
diff changeset
71 J::m_fn9 (const F &, bool, D<CandPair> &)
kono
parents:
diff changeset
72 {
kono
parents:
diff changeset
73 D<int> a;
kono
parents:
diff changeset
74 for (B b; b != a.m_fn2 ();)
kono
parents:
diff changeset
75 ;
kono
parents:
diff changeset
76 }
kono
parents:
diff changeset
77 inline void
kono
parents:
diff changeset
78 fn2 (F p1, int, int, J *p4, D<CandPair>)
kono
parents:
diff changeset
79 {
kono
parents:
diff changeset
80 D<CandPair> d;
kono
parents:
diff changeset
81 d.m_fn3 ();
kono
parents:
diff changeset
82 p4->m_fn9 (p1, 0, d);
kono
parents:
diff changeset
83 for (D<I *>::const_iterator e = c.m_fn1 (); e != c.m_fn2 ();)
kono
parents:
diff changeset
84 (*e)->m_fn9 (p1, 0, d);
kono
parents:
diff changeset
85 }
kono
parents:
diff changeset
86 void
kono
parents:
diff changeset
87 H::m_fn7 (const F &, bool &)
kono
parents:
diff changeset
88 {
kono
parents:
diff changeset
89 A<F> f;
kono
parents:
diff changeset
90 D<F> g;
kono
parents:
diff changeset
91 F h;
kono
parents:
diff changeset
92 m_fn8 (g, f.first, h);
kono
parents:
diff changeset
93 }
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
94 void
111
kono
parents:
diff changeset
95 H::m_fn8 (const D<F> &p1, const F &, F &)
kono
parents:
diff changeset
96 {
kono
parents:
diff changeset
97 F i;
kono
parents:
diff changeset
98 p1.m_fn1 ();
kono
parents:
diff changeset
99 D<CandPair> j;
kono
parents:
diff changeset
100 fn2 (i, 0, 0, 0, j);
kono
parents:
diff changeset
101 }