annotate gcc/testsuite/g++.dg/torture/pr64568.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 // { dg-additional-options "-std=c++11" }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 namespace std
kono
parents:
diff changeset
5 {
kono
parents:
diff changeset
6 typedef long unsigned size_t;
kono
parents:
diff changeset
7 template <typename> class complex;
kono
parents:
diff changeset
8 template <typename _Tp> complex<_Tp> operator+(complex<_Tp>, complex<_Tp>)
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 complex<_Tp> a = 0;
kono
parents:
diff changeset
11 a += 0;
kono
parents:
diff changeset
12 return a;
kono
parents:
diff changeset
13 }
kono
parents:
diff changeset
14 template <> struct complex<double>
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 complex (int __i) : _M_value{ __i } {}
kono
parents:
diff changeset
17 int imag ();
kono
parents:
diff changeset
18 void operator+=(complex __z) { _M_value = __z.imag (); }
kono
parents:
diff changeset
19 _Complex double _M_value;
kono
parents:
diff changeset
20 };
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22 class A
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 public:
kono
parents:
diff changeset
25 A (int);
kono
parents:
diff changeset
26 std::complex<double> &operator[](int i) { return data_[i]; }
kono
parents:
diff changeset
27 std::complex<double> *data_;
kono
parents:
diff changeset
28 };
kono
parents:
diff changeset
29 struct B
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 static std::complex<double>
kono
parents:
diff changeset
32 apply (std::complex<double> t1, std::complex<double> t2)
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 return t1 + t2;
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36 };
kono
parents:
diff changeset
37 template <class T1, class> struct C
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 static void
kono
parents:
diff changeset
40 apply (T1 t1, std::complex<double> t2)
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 t1 = t2;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44 };
kono
parents:
diff changeset
45 template <class E> class D
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 public:
kono
parents:
diff changeset
48 E operator()();
kono
parents:
diff changeset
49 };
kono
parents:
diff changeset
50 class G : public D<G>
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 public:
kono
parents:
diff changeset
53 typedef std::complex<double> value_type;
kono
parents:
diff changeset
54 value_type operator()(int) { return B::apply (0, 0); }
kono
parents:
diff changeset
55 };
kono
parents:
diff changeset
56 template <class E1, class E2> G operator+(D<E1>, D<E2>);
kono
parents:
diff changeset
57 template <template <class, class> class F, class V, class E>
kono
parents:
diff changeset
58 void
kono
parents:
diff changeset
59 indexing_vector_assign (V v, D<E> e)
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 for (int i;; ++i)
kono
parents:
diff changeset
62 F<typename V::reference, typename E::value_type>::apply (v (i), e ()(0));
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64 template <template <class, class> class F, class V, class E>
kono
parents:
diff changeset
65 void
kono
parents:
diff changeset
66 vector_assign (V v, D<E> e, int)
kono
parents:
diff changeset
67 {
kono
parents:
diff changeset
68 indexing_vector_assign<F> (v, e);
kono
parents:
diff changeset
69 }
kono
parents:
diff changeset
70 template <template <class, class> class F, class V, class E>
kono
parents:
diff changeset
71 void
kono
parents:
diff changeset
72 vector_assign (V v, D<E> e)
kono
parents:
diff changeset
73 {
kono
parents:
diff changeset
74 vector_assign<F> (v, e, typename V::storage_category ());
kono
parents:
diff changeset
75 }
kono
parents:
diff changeset
76 class H : public D<int>
kono
parents:
diff changeset
77 {
kono
parents:
diff changeset
78 public:
kono
parents:
diff changeset
79 typedef std::complex<double> &reference;
kono
parents:
diff changeset
80 typedef int storage_category;
kono
parents:
diff changeset
81 H (int);
kono
parents:
diff changeset
82 template <class AE> H (D<AE> ae) : data_ (0)
kono
parents:
diff changeset
83 {
kono
parents:
diff changeset
84 vector_assign<C> (*this, ae);
kono
parents:
diff changeset
85 }
kono
parents:
diff changeset
86 A
kono
parents:
diff changeset
87 data ()
kono
parents:
diff changeset
88 {
kono
parents:
diff changeset
89 return data_;
kono
parents:
diff changeset
90 }
kono
parents:
diff changeset
91 reference operator()(int i) { return data ()[i]; }
kono
parents:
diff changeset
92 A data_;
kono
parents:
diff changeset
93 };
kono
parents:
diff changeset
94 template <class T1, class V1, class T2, class V2>
kono
parents:
diff changeset
95 void
kono
parents:
diff changeset
96 rot (T1, V1 v1, T2, V2 v2)
kono
parents:
diff changeset
97 {
kono
parents:
diff changeset
98 H (v1 + v2);
kono
parents:
diff changeset
99 }
kono
parents:
diff changeset
100 template <class, unsigned long> struct F
kono
parents:
diff changeset
101 {
kono
parents:
diff changeset
102 void test ();
kono
parents:
diff changeset
103 };
kono
parents:
diff changeset
104 template struct F<H, 3>;
kono
parents:
diff changeset
105 template <class V, std::size_t N>
kono
parents:
diff changeset
106 void
kono
parents:
diff changeset
107 F<V, N>::test ()
kono
parents:
diff changeset
108 {
kono
parents:
diff changeset
109 V b (0), c (0);
kono
parents:
diff changeset
110 rot (0, b, 0, c);
kono
parents:
diff changeset
111 }