2011-09-23 17:32:31 -05:00
|
|
|
use std;
|
2011-12-13 18:25:51 -06:00
|
|
|
import comm;
|
|
|
|
import task;
|
|
|
|
import uint;
|
2011-09-23 17:32:31 -05:00
|
|
|
|
2012-01-04 23:14:53 -06:00
|
|
|
fn child(c: comm::chan<~uint>, i: uint) {
|
2011-09-23 17:32:31 -05:00
|
|
|
comm::send(c, ~i);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let p = comm::port();
|
2012-01-04 23:14:53 -06:00
|
|
|
let ch = comm::chan(p);
|
2011-09-23 17:32:31 -05:00
|
|
|
let n = 100u;
|
|
|
|
let expected = 0u;
|
2011-10-21 06:14:28 -05:00
|
|
|
uint::range(0u, n) {|i|
|
2012-01-04 23:14:53 -06:00
|
|
|
task::spawn {|| child(ch, i); };
|
2011-09-23 17:32:31 -05:00
|
|
|
expected += i;
|
2011-10-21 07:12:12 -05:00
|
|
|
}
|
2011-09-23 17:32:31 -05:00
|
|
|
|
|
|
|
let actual = 0u;
|
2011-10-21 06:14:28 -05:00
|
|
|
uint::range(0u, n) {|_i|
|
2011-09-23 17:32:31 -05:00
|
|
|
let j = comm::recv(p);
|
|
|
|
actual += *j;
|
2011-10-21 07:12:12 -05:00
|
|
|
}
|
2011-09-23 17:32:31 -05:00
|
|
|
|
|
|
|
assert expected == actual;
|
|
|
|
}
|