-
Notifications
You must be signed in to change notification settings - Fork 13.2k
/
Copy pathtask-comm-7.rs
47 lines (40 loc) · 1.2 KB
/
task-comm-7.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
use std;
import std._task.join;
impure fn main() -> () {
test00();
}
impure fn test00_start(chan[int] c, int start, int number_of_messages) {
let int i = 0;
while (i < number_of_messages) {
c <| start + i;
i += 1;
}
}
impure fn test00() {
let int r = 0;
let int sum = 0;
let port[int] p = port();
let int number_of_messages = 10;
let task t0 = spawn test00_start(chan(p),
number_of_messages * 0, number_of_messages);
let task t1 = spawn test00_start(chan(p),
number_of_messages * 1, number_of_messages);
let task t2 = spawn test00_start(chan(p),
number_of_messages * 2, number_of_messages);
let task t3 = spawn test00_start(chan(p),
number_of_messages * 3, number_of_messages);
let int i = 0;
while (i < number_of_messages) {
r <- p; sum += r;
r <- p; sum += r;
r <- p; sum += r;
r <- p; sum += r;
i += 1;
}
join(t0);
join(t1);
join(t2);
join(t3);
check (sum == (((number_of_messages * 4) *
((number_of_messages * 4) - 1)) / 2));
}