annotate gcc/testsuite/g++.dg/torture/pr69355.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++/69355
kono
parents:
diff changeset
2 // { dg-do run }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 template <int> struct A;
kono
parents:
diff changeset
5 template <> struct A<1> {};
kono
parents:
diff changeset
6 template <class Obj, int> struct B
kono
parents:
diff changeset
7 {
kono
parents:
diff changeset
8 template <class T> struct C
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 typedef T *iterator;
kono
parents:
diff changeset
11 C (iterator p1) : m_iter (p1) {}
kono
parents:
diff changeset
12 void operator, (T p1) { *m_iter = p1; }
kono
parents:
diff changeset
13 iterator m_iter;
kono
parents:
diff changeset
14 };
kono
parents:
diff changeset
15 typedef double *iterator;
kono
parents:
diff changeset
16 B (Obj &p1, double) : m_object (p1) {}
kono
parents:
diff changeset
17 C<double> operator, (double);
kono
parents:
diff changeset
18 Obj &m_object;
kono
parents:
diff changeset
19 };
kono
parents:
diff changeset
20 template <class Obj, int LEN>
kono
parents:
diff changeset
21 typename B<Obj, LEN>::template C<double>
kono
parents:
diff changeset
22 B<Obj, LEN>::operator, (double p1)
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 iterator a = m_object.data (), b = a + 1;
kono
parents:
diff changeset
25 *a = 1;
kono
parents:
diff changeset
26 *b = p1;
kono
parents:
diff changeset
27 return C<double>(b + 1);
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29 class D {};
kono
parents:
diff changeset
30 inline double operator+(const double &p1, D) { return p1; }
kono
parents:
diff changeset
31 template <int> class U;
kono
parents:
diff changeset
32 template <int Sz, int K = 0> struct F
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 enum { doIt = K < Sz - 1 ? 1 : 0 };
kono
parents:
diff changeset
35 template <class Dest, class Src, class Assign>
kono
parents:
diff changeset
36 static void assign (Dest &p1, Src &p2, Assign &p3)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 p3.apply_on (p1 (K), p2 (K));
kono
parents:
diff changeset
39 F<Sz * doIt, (K + 1) * doIt>::assign (p1, p2, p3);
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41 template <class Dest, class Src> static double dot (Dest &p1, Src &p2)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 return p1 (K) * p2 (K) + F<Sz * doIt, (K + 1) * doIt>::dot (p1, p2);
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45 };
kono
parents:
diff changeset
46 template <> struct F<0>
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 template <class Dest, class Src, class Assign>
kono
parents:
diff changeset
49 static void assign (Dest &, Src &, Assign &) {}
kono
parents:
diff changeset
50 template <class Dest, class Src> static D dot (Dest &, Src &) { return D (); }
kono
parents:
diff changeset
51 };
kono
parents:
diff changeset
52 template <class E, int Sz> struct G
kono
parents:
diff changeset
53 {
kono
parents:
diff changeset
54 enum { ops_assign, use_meta };
kono
parents:
diff changeset
55 G (const E &p1) : m_expr (p1) {}
kono
parents:
diff changeset
56 double operator()(int p1) const { return m_expr (p1); }
kono
parents:
diff changeset
57 template <class Dest, class Src, class Assign>
kono
parents:
diff changeset
58 static void do_assign (A<1>, Dest &p2, Src &p3, Assign &p4)
kono
parents:
diff changeset
59 {
kono
parents:
diff changeset
60 F<Sz>::assign (p2, p3, p4);
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62 template <class Dest, class Assign>
kono
parents:
diff changeset
63 void assign_to (Dest &p1, const Assign &p2) const
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 do_assign (A<1>(), p1, *this, p2);
kono
parents:
diff changeset
66 }
kono
parents:
diff changeset
67 E m_expr;
kono
parents:
diff changeset
68 };
kono
parents:
diff changeset
69 struct H
kono
parents:
diff changeset
70 {
kono
parents:
diff changeset
71 static double apply_on (double p1, long double p2) { return p1 / p2; }
kono
parents:
diff changeset
72 static void apply_on (double &p1, double p2) { p1 = p2; }
kono
parents:
diff changeset
73 };
kono
parents:
diff changeset
74 template <class E1, class E2> struct I
kono
parents:
diff changeset
75 {
kono
parents:
diff changeset
76 I (const E1 &p1, const E2 &p2) : m_lhs (p1), m_rhs (p2) {}
kono
parents:
diff changeset
77 double operator()(int p1) const
kono
parents:
diff changeset
78 {
kono
parents:
diff changeset
79 double c = m_lhs (p1);
kono
parents:
diff changeset
80 return H::apply_on (c, m_rhs (0));
kono
parents:
diff changeset
81 }
kono
parents:
diff changeset
82 E1 m_lhs;
kono
parents:
diff changeset
83 const E2 m_rhs;
kono
parents:
diff changeset
84 };
kono
parents:
diff changeset
85 struct J
kono
parents:
diff changeset
86 {
kono
parents:
diff changeset
87 J (double p1) : m_data (p1) {}
kono
parents:
diff changeset
88 long double operator()(int) const { return m_data; }
kono
parents:
diff changeset
89 long double m_data;
kono
parents:
diff changeset
90 };
kono
parents:
diff changeset
91 template <int Sz> struct K
kono
parents:
diff changeset
92 {
kono
parents:
diff changeset
93 K (const U<Sz> &p1) : m_data (p1.data ()) {}
kono
parents:
diff changeset
94 double operator()(int p1) const { return m_data[p1]; }
kono
parents:
diff changeset
95 const double *m_data;
kono
parents:
diff changeset
96 };
kono
parents:
diff changeset
97 template <int Sz> struct U
kono
parents:
diff changeset
98 {
kono
parents:
diff changeset
99 U () {}
kono
parents:
diff changeset
100 U (const U &p1)
kono
parents:
diff changeset
101 {
kono
parents:
diff changeset
102 *this = G<ConstReference, Sz>(p1.const_ref ());
kono
parents:
diff changeset
103 }
kono
parents:
diff changeset
104 B<U, Sz> operator=(double) { return B<U, Sz>(*this, 0); }
kono
parents:
diff changeset
105 double *data () { return m_data; }
kono
parents:
diff changeset
106 const double *data () const { return m_data; }
kono
parents:
diff changeset
107 double &operator()(int p1) { return m_data[p1]; }
kono
parents:
diff changeset
108 double operator()(int p1) const { return m_data[p1]; }
kono
parents:
diff changeset
109 typedef K<Sz> ConstReference;
kono
parents:
diff changeset
110 ConstReference const_ref () const { return *this; }
kono
parents:
diff changeset
111 template <class E> void operator=(const G<E, Sz> &p1)
kono
parents:
diff changeset
112 {
kono
parents:
diff changeset
113 p1.assign_to (*this, H ());
kono
parents:
diff changeset
114 }
kono
parents:
diff changeset
115 double m_data[Sz];
kono
parents:
diff changeset
116 };
kono
parents:
diff changeset
117 template <int Sz>
kono
parents:
diff changeset
118 G<I<K<Sz>, J>, Sz> div (U<Sz> &p1, double p2)
kono
parents:
diff changeset
119 {
kono
parents:
diff changeset
120 typedef I<K<Sz>, J> expr_type;
kono
parents:
diff changeset
121 return G<expr_type, Sz>(expr_type (p1.const_ref (), p2));
kono
parents:
diff changeset
122 }
kono
parents:
diff changeset
123 template <int Sz> double norm2 (U<Sz> &p1)
kono
parents:
diff changeset
124 {
kono
parents:
diff changeset
125 return __builtin_sqrt (F<Sz>::dot (p1, p1));
kono
parents:
diff changeset
126 }
kono
parents:
diff changeset
127 template <int Sz>
kono
parents:
diff changeset
128 G<I<K<Sz>, J>, Sz> operator/(U<Sz> &p1, double p2)
kono
parents:
diff changeset
129 {
kono
parents:
diff changeset
130 return div (p1, p2);
kono
parents:
diff changeset
131 }
kono
parents:
diff changeset
132 typedef U<3> V;
kono
parents:
diff changeset
133 V foo (V p1)
kono
parents:
diff changeset
134 {
kono
parents:
diff changeset
135 double e = norm2 (p1);
kono
parents:
diff changeset
136 V r;
kono
parents:
diff changeset
137 r = p1 / e;
kono
parents:
diff changeset
138 return r;
kono
parents:
diff changeset
139 }
kono
parents:
diff changeset
140 int
kono
parents:
diff changeset
141 main ()
kono
parents:
diff changeset
142 {
kono
parents:
diff changeset
143 V f;
kono
parents:
diff changeset
144 f = 1, 2, 3;
kono
parents:
diff changeset
145 V r = foo (f);
kono
parents:
diff changeset
146 if (__builtin_fabs (r (0) - 0.267261) > 0.01
kono
parents:
diff changeset
147 || __builtin_fabs (r (1) - 0.534522) > 0.01
kono
parents:
diff changeset
148 || __builtin_fabs (r (2) - 0.801784) > 0.01)
kono
parents:
diff changeset
149 __builtin_abort ();
kono
parents:
diff changeset
150 }