1*9120562dSMichael Kruse // RUN: %libomp-cxx20-compile-and-run | FileCheck %s --match-full-lines
2*9120562dSMichael Kruse
3*9120562dSMichael Kruse #ifndef HEADER
4*9120562dSMichael Kruse #define HEADER
5*9120562dSMichael Kruse
6*9120562dSMichael Kruse #include <cstdlib>
7*9120562dSMichael Kruse #include <cstdarg>
8*9120562dSMichael Kruse #include <cstdio>
9*9120562dSMichael Kruse #include <vector>
10*9120562dSMichael Kruse
11*9120562dSMichael Kruse struct Reporter {
12*9120562dSMichael Kruse const char *name;
13*9120562dSMichael Kruse
ReporterReporter14*9120562dSMichael Kruse Reporter(const char *name) : name(name) { print("ctor"); }
15*9120562dSMichael Kruse
ReporterReporter16*9120562dSMichael Kruse Reporter() : name("<anon>") { print("ctor"); }
17*9120562dSMichael Kruse
ReporterReporter18*9120562dSMichael Kruse Reporter(const Reporter &that) : name(that.name) { print("copy ctor"); }
19*9120562dSMichael Kruse
ReporterReporter20*9120562dSMichael Kruse Reporter(Reporter &&that) : name(that.name) { print("move ctor"); }
21*9120562dSMichael Kruse
~ReporterReporter22*9120562dSMichael Kruse ~Reporter() { print("dtor"); }
23*9120562dSMichael Kruse
operator =Reporter24*9120562dSMichael Kruse const Reporter &operator=(const Reporter &that) {
25*9120562dSMichael Kruse print("copy assign");
26*9120562dSMichael Kruse this->name = that.name;
27*9120562dSMichael Kruse return *this;
28*9120562dSMichael Kruse }
29*9120562dSMichael Kruse
operator =Reporter30*9120562dSMichael Kruse const Reporter &operator=(Reporter &&that) {
31*9120562dSMichael Kruse print("move assign");
32*9120562dSMichael Kruse this->name = that.name;
33*9120562dSMichael Kruse return *this;
34*9120562dSMichael Kruse }
35*9120562dSMichael Kruse
36*9120562dSMichael Kruse struct Iterator {
37*9120562dSMichael Kruse const Reporter *owner;
38*9120562dSMichael Kruse int pos;
39*9120562dSMichael Kruse
IteratorReporter::Iterator40*9120562dSMichael Kruse Iterator(const Reporter *owner, int pos) : owner(owner), pos(pos) {}
41*9120562dSMichael Kruse
IteratorReporter::Iterator42*9120562dSMichael Kruse Iterator(const Iterator &that) : owner(that.owner), pos(that.pos) {
43*9120562dSMichael Kruse owner->print("iterator copy ctor");
44*9120562dSMichael Kruse }
45*9120562dSMichael Kruse
IteratorReporter::Iterator46*9120562dSMichael Kruse Iterator(Iterator &&that) : owner(that.owner), pos(that.pos) {
47*9120562dSMichael Kruse owner->print("iterator move ctor");
48*9120562dSMichael Kruse }
49*9120562dSMichael Kruse
~IteratorReporter::Iterator50*9120562dSMichael Kruse ~Iterator() { owner->print("iterator dtor"); }
51*9120562dSMichael Kruse
operator =Reporter::Iterator52*9120562dSMichael Kruse const Iterator &operator=(const Iterator &that) {
53*9120562dSMichael Kruse owner->print("iterator copy assign");
54*9120562dSMichael Kruse this->owner = that.owner;
55*9120562dSMichael Kruse this->pos = that.pos;
56*9120562dSMichael Kruse return *this;
57*9120562dSMichael Kruse }
58*9120562dSMichael Kruse
operator =Reporter::Iterator59*9120562dSMichael Kruse const Iterator &operator=(Iterator &&that) {
60*9120562dSMichael Kruse owner->print("iterator move assign");
61*9120562dSMichael Kruse this->owner = that.owner;
62*9120562dSMichael Kruse this->pos = that.pos;
63*9120562dSMichael Kruse return *this;
64*9120562dSMichael Kruse }
65*9120562dSMichael Kruse
operator ==Reporter::Iterator66*9120562dSMichael Kruse bool operator==(const Iterator &that) const {
67*9120562dSMichael Kruse owner->print("iterator %d == %d", 2 - this->pos, 2 - that.pos);
68*9120562dSMichael Kruse return this->pos == that.pos;
69*9120562dSMichael Kruse }
70*9120562dSMichael Kruse
operator ++Reporter::Iterator71*9120562dSMichael Kruse Iterator &operator++() {
72*9120562dSMichael Kruse owner->print("iterator prefix ++");
73*9120562dSMichael Kruse pos -= 1;
74*9120562dSMichael Kruse return *this;
75*9120562dSMichael Kruse }
76*9120562dSMichael Kruse
operator ++Reporter::Iterator77*9120562dSMichael Kruse Iterator operator++(int) {
78*9120562dSMichael Kruse owner->print("iterator postfix ++");
79*9120562dSMichael Kruse auto result = *this;
80*9120562dSMichael Kruse pos -= 1;
81*9120562dSMichael Kruse return result;
82*9120562dSMichael Kruse }
83*9120562dSMichael Kruse
operator *Reporter::Iterator84*9120562dSMichael Kruse int operator*() const {
85*9120562dSMichael Kruse int result = 2 - pos;
86*9120562dSMichael Kruse owner->print("iterator deref: %i", result);
87*9120562dSMichael Kruse return result;
88*9120562dSMichael Kruse }
89*9120562dSMichael Kruse
operator -Reporter::Iterator90*9120562dSMichael Kruse size_t operator-(const Iterator &that) const {
91*9120562dSMichael Kruse int result = (2 - this->pos) - (2 - that.pos);
92*9120562dSMichael Kruse owner->print("iterator distance: %d", result);
93*9120562dSMichael Kruse return result;
94*9120562dSMichael Kruse }
95*9120562dSMichael Kruse
operator +Reporter::Iterator96*9120562dSMichael Kruse Iterator operator+(int steps) const {
97*9120562dSMichael Kruse owner->print("iterator advance: %i += %i", 2 - this->pos, steps);
98*9120562dSMichael Kruse return Iterator(owner, pos - steps);
99*9120562dSMichael Kruse }
100*9120562dSMichael Kruse };
101*9120562dSMichael Kruse
beginReporter102*9120562dSMichael Kruse Iterator begin() const {
103*9120562dSMichael Kruse print("begin()");
104*9120562dSMichael Kruse return Iterator(this, 2);
105*9120562dSMichael Kruse }
106*9120562dSMichael Kruse
endReporter107*9120562dSMichael Kruse Iterator end() const {
108*9120562dSMichael Kruse print("end()");
109*9120562dSMichael Kruse return Iterator(this, -1);
110*9120562dSMichael Kruse }
111*9120562dSMichael Kruse
printReporter112*9120562dSMichael Kruse void print(const char *msg, ...) const {
113*9120562dSMichael Kruse va_list args;
114*9120562dSMichael Kruse va_start(args, msg);
115*9120562dSMichael Kruse printf("[%s] ", name);
116*9120562dSMichael Kruse vprintf(msg, args);
117*9120562dSMichael Kruse printf("\n");
118*9120562dSMichael Kruse va_end(args);
119*9120562dSMichael Kruse }
120*9120562dSMichael Kruse };
121*9120562dSMichael Kruse
main()122*9120562dSMichael Kruse int main() {
123*9120562dSMichael Kruse printf("do\n");
124*9120562dSMichael Kruse #pragma omp parallel for collapse(3) num_threads(1)
125*9120562dSMichael Kruse for (int i = 0; i < 3; ++i)
126*9120562dSMichael Kruse #pragma omp tile sizes(2, 2)
127*9120562dSMichael Kruse for (Reporter c{"C"}; auto &&v : Reporter("A"))
128*9120562dSMichael Kruse for (Reporter d{"D"}; auto &&w : Reporter("B"))
129*9120562dSMichael Kruse printf("i=%d v=%d w=%d\n", i, v, w);
130*9120562dSMichael Kruse printf("done\n");
131*9120562dSMichael Kruse return EXIT_SUCCESS;
132*9120562dSMichael Kruse }
133*9120562dSMichael Kruse
134*9120562dSMichael Kruse #endif /* HEADER */
135*9120562dSMichael Kruse
136*9120562dSMichael Kruse // CHECK: do
137*9120562dSMichael Kruse // CHECK-NEXT: [C] ctor
138*9120562dSMichael Kruse // CHECK-NEXT: [A] ctor
139*9120562dSMichael Kruse // CHECK-NEXT: [A] end()
140*9120562dSMichael Kruse // CHECK-NEXT: [A] begin()
141*9120562dSMichael Kruse // CHECK-NEXT: [A] begin()
142*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator distance: 3
143*9120562dSMichael Kruse // CHECK-NEXT: [D] ctor
144*9120562dSMichael Kruse // CHECK-NEXT: [B] ctor
145*9120562dSMichael Kruse // CHECK-NEXT: [B] end()
146*9120562dSMichael Kruse // CHECK-NEXT: [B] begin()
147*9120562dSMichael Kruse // CHECK-NEXT: [B] begin()
148*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator distance: 3
149*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 0
150*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
151*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 0
152*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
153*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
154*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
155*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=0 w=0
156*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
157*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
158*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
159*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
160*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=0 w=1
161*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
162*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
163*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 1
164*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
165*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 1
166*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
167*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
168*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
169*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=1 w=0
170*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
171*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
172*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
173*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
174*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=1 w=1
175*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
176*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
177*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 0
178*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
179*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 0
180*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
181*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
182*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
183*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=0 w=2
184*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
185*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
186*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 1
187*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
188*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 1
189*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
190*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
191*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
192*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=1 w=2
193*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
194*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
195*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 2
196*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
197*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 2
198*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
199*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
200*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
201*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=2 w=0
202*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
203*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
204*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
205*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
206*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=2 w=1
207*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
208*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
209*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 2
210*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
211*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 2
212*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
213*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
214*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
215*9120562dSMichael Kruse // CHECK-NEXT: i=0 v=2 w=2
216*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
217*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
218*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 0
219*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
220*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 0
221*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
222*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
223*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
224*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=0 w=0
225*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
226*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
227*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
228*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
229*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=0 w=1
230*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
231*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
232*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 1
233*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
234*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 1
235*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
236*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
237*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
238*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=1 w=0
239*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
240*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
241*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
242*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
243*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=1 w=1
244*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
245*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
246*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 0
247*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
248*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 0
249*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
250*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
251*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
252*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=0 w=2
253*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
254*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
255*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 1
256*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
257*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 1
258*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
259*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
260*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
261*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=1 w=2
262*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
263*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
264*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 2
265*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
266*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 2
267*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
268*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
269*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
270*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=2 w=0
271*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
272*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
273*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
274*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
275*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=2 w=1
276*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
277*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
278*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 2
279*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
280*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 2
281*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
282*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
283*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
284*9120562dSMichael Kruse // CHECK-NEXT: i=1 v=2 w=2
285*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
286*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
287*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 0
288*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
289*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 0
290*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
291*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
292*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
293*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=0 w=0
294*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
295*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
296*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
297*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
298*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=0 w=1
299*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
300*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
301*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 1
302*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
303*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 1
304*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
305*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
306*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
307*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=1 w=0
308*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
309*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
310*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
311*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
312*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=1 w=1
313*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
314*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
315*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 0
316*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
317*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 0
318*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
319*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
320*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
321*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=0 w=2
322*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
323*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
324*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 1
325*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
326*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 1
327*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
328*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
329*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
330*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=1 w=2
331*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
332*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
333*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 2
334*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
335*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 2
336*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 0
337*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
338*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 0
339*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=2 w=0
340*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
341*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 1
342*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
343*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 1
344*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=2 w=1
345*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
346*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
347*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator advance: 0 += 2
348*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator move assign
349*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator deref: 2
350*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator advance: 0 += 2
351*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator move assign
352*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator deref: 2
353*9120562dSMichael Kruse // CHECK-NEXT: i=2 v=2 w=2
354*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
355*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
356*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
357*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
358*9120562dSMichael Kruse // CHECK-NEXT: [B] iterator dtor
359*9120562dSMichael Kruse // CHECK-NEXT: [B] dtor
360*9120562dSMichael Kruse // CHECK-NEXT: [D] dtor
361*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
362*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
363*9120562dSMichael Kruse // CHECK-NEXT: [A] iterator dtor
364*9120562dSMichael Kruse // CHECK-NEXT: [A] dtor
365*9120562dSMichael Kruse // CHECK-NEXT: [C] dtor
366*9120562dSMichael Kruse // CHECK-NEXT: done
367