LLVM OpenMP 22.0.0git
parallel-wsloop-collapse-foreach.cpp
Go to the documentation of this file.
1// RUN: %libomp-cxx20-compile-and-run | FileCheck %s --match-full-lines
2
3#ifndef HEADER
4#define HEADER
5
6#include <cstdlib>
7#include <cstdarg>
8#include <cstdio>
9#include <vector>
10
11struct Reporter {
12 const char *name;
13
14 Reporter(const char *name) : name(name) { print("ctor"); }
15
16 Reporter() : name("<anon>") { print("ctor"); }
17
18 Reporter(const Reporter &that) : name(that.name) { print("copy ctor"); }
19
20 Reporter(Reporter &&that) : name(that.name) { print("move ctor"); }
21
22 ~Reporter() { print("dtor"); }
23
24 const Reporter &operator=(const Reporter &that) {
25 print("copy assign");
26 this->name = that.name;
27 return *this;
28 }
29
30 const Reporter &operator=(Reporter &&that) {
31 print("move assign");
32 this->name = that.name;
33 return *this;
34 }
35
36 struct Iterator {
37 const Reporter *owner;
38 int pos;
39
40 Iterator(const Reporter *owner, int pos) : owner(owner), pos(pos) {}
41
42 Iterator(const Iterator &that) : owner(that.owner), pos(that.pos) {
43 owner->print("iterator copy ctor");
44 }
45
46 Iterator(Iterator &&that) : owner(that.owner), pos(that.pos) {
47 owner->print("iterator move ctor");
48 }
49
50 ~Iterator() { owner->print("iterator dtor"); }
51
52 const Iterator &operator=(const Iterator &that) {
53 owner->print("iterator copy assign");
54 this->owner = that.owner;
55 this->pos = that.pos;
56 return *this;
57 }
58
59 const Iterator &operator=(Iterator &&that) {
60 owner->print("iterator move assign");
61 this->owner = that.owner;
62 this->pos = that.pos;
63 return *this;
64 }
65
66 bool operator==(const Iterator &that) const {
67 owner->print("iterator %d == %d", 2 - this->pos, 2 - that.pos);
68 return this->pos == that.pos;
69 }
70
72 owner->print("iterator prefix ++");
73 pos -= 1;
74 return *this;
75 }
76
78 owner->print("iterator postfix ++");
79 auto result = *this;
80 pos -= 1;
81 return result;
82 }
83
84 int operator*() const {
85 int result = 2 - pos;
86 owner->print("iterator deref: %i", result);
87 return result;
88 }
89
90 size_t operator-(const Iterator &that) const {
91 int result = (2 - this->pos) - (2 - that.pos);
92 owner->print("iterator distance: %d", result);
93 return result;
94 }
95
96 Iterator operator+(int steps) const {
97 owner->print("iterator advance: %i += %i", 2 - this->pos, steps);
98 return Iterator(owner, pos - steps);
99 }
100
101 void print(const char *msg) const { owner->print(msg); }
102 };
103
104 Iterator begin() const {
105 print("begin()");
106 return Iterator(this, 2);
107 }
108
109 Iterator end() const {
110 print("end()");
111 return Iterator(this, -1);
112 }
113
114 void print(const char *msg, ...) const {
115 va_list args;
116 va_start(args, msg);
117 printf("[%s] ", name);
118 vprintf(msg, args);
119 printf("\n");
120 va_end(args);
121 }
122};
123
124int main() {
125 printf("do\n");
126#pragma omp parallel for collapse(2) num_threads(1)
127 for (int i = 0; i < 3; ++i)
128#pragma omp fuse
129 {
130 for (Reporter c{"init-stmt"}; auto &&v : Reporter("range"))
131 printf("i=%d v=%d\n", i, v);
132 for (int vv = 0; vv < 3; ++vv)
133 printf("i=%d vv=%d\n", i, vv);
134 }
135 printf("done\n");
136 return EXIT_SUCCESS;
137}
138
139#endif /* HEADER */
140
141// CHECK: do
142// CHECK-NEXT: [init-stmt] ctor
143// CHECK-NEXT: [range] ctor
144// CHECK-NEXT: [range] end()
145// CHECK-NEXT: [range] begin()
146// CHECK-NEXT: [range] begin()
147// CHECK-NEXT: [range] iterator distance: 3
148// CHECK-NEXT: [range] iterator advance: 0 += 0
149// CHECK-NEXT: [range] iterator move assign
150// CHECK-NEXT: [range] iterator deref: 0
151// CHECK-NEXT: i=0 v=0
152// CHECK-NEXT: [range] iterator dtor
153// CHECK-NEXT: i=0 vv=0
154// CHECK-NEXT: [range] iterator advance: 0 += 1
155// CHECK-NEXT: [range] iterator move assign
156// CHECK-NEXT: [range] iterator deref: 1
157// CHECK-NEXT: i=0 v=1
158// CHECK-NEXT: [range] iterator dtor
159// CHECK-NEXT: i=0 vv=1
160// CHECK-NEXT: [range] iterator advance: 0 += 2
161// CHECK-NEXT: [range] iterator move assign
162// CHECK-NEXT: [range] iterator deref: 2
163// CHECK-NEXT: i=0 v=2
164// CHECK-NEXT: [range] iterator dtor
165// CHECK-NEXT: i=0 vv=2
166// CHECK-NEXT: [range] iterator advance: 0 += 0
167// CHECK-NEXT: [range] iterator move assign
168// CHECK-NEXT: [range] iterator deref: 0
169// CHECK-NEXT: i=1 v=0
170// CHECK-NEXT: [range] iterator dtor
171// CHECK-NEXT: i=1 vv=0
172// CHECK-NEXT: [range] iterator advance: 0 += 1
173// CHECK-NEXT: [range] iterator move assign
174// CHECK-NEXT: [range] iterator deref: 1
175// CHECK-NEXT: i=1 v=1
176// CHECK-NEXT: [range] iterator dtor
177// CHECK-NEXT: i=1 vv=1
178// CHECK-NEXT: [range] iterator advance: 0 += 2
179// CHECK-NEXT: [range] iterator move assign
180// CHECK-NEXT: [range] iterator deref: 2
181// CHECK-NEXT: i=1 v=2
182// CHECK-NEXT: [range] iterator dtor
183// CHECK-NEXT: i=1 vv=2
184// CHECK-NEXT: [range] iterator advance: 0 += 0
185// CHECK-NEXT: [range] iterator move assign
186// CHECK-NEXT: [range] iterator deref: 0
187// CHECK-NEXT: i=2 v=0
188// CHECK-NEXT: [range] iterator dtor
189// CHECK-NEXT: i=2 vv=0
190// CHECK-NEXT: [range] iterator advance: 0 += 1
191// CHECK-NEXT: [range] iterator move assign
192// CHECK-NEXT: [range] iterator deref: 1
193// CHECK-NEXT: i=2 v=1
194// CHECK-NEXT: [range] iterator dtor
195// CHECK-NEXT: i=2 vv=1
196// CHECK-NEXT: [range] iterator advance: 0 += 2
197// CHECK-NEXT: [range] iterator move assign
198// CHECK-NEXT: [range] iterator deref: 2
199// CHECK-NEXT: i=2 v=2
200// CHECK-NEXT: [range] iterator dtor
201// CHECK-NEXT: i=2 vv=2
202// CHECK-NEXT: [range] iterator dtor
203// CHECK-NEXT: [range] iterator dtor
204// CHECK-NEXT: [range] iterator dtor
205// CHECK-NEXT: [range] dtor
206// CHECK-NEXT: [init-stmt] dtor
207// CHECK-NEXT: done
int result[2]
__itt_string_handle * name
Definition ittnotify.h:3305
#define args
#define i
Definition kmp_stub.cpp:87
const Reporter * owner
Definition foreach.cpp:37
const Iterator & operator=(const Iterator &that)
bool operator==(const Iterator &that) const
Iterator operator+(int steps) const
Iterator(const Reporter *owner, int pos)
size_t operator-(const Iterator &that) const
const Iterator & operator=(Iterator &&that)
void print(const char *msg) const
void print(const char *msg,...) const
Definition foreach.cpp:114
const Reporter & operator=(const Reporter &that)
const Reporter & operator=(Reporter &&that)
const char * name
Definition foreach.cpp:12
Reporter(const Reporter &that)