2011-12-13 18:25:51 -06:00
|
|
|
import task;
|
2011-09-20 13:47:22 -05:00
|
|
|
|
|
|
|
fn main() {
|
2012-08-16 19:50:21 -05:00
|
|
|
let po = pipes::PortSet();
|
2011-07-27 07:48:34 -05:00
|
|
|
|
|
|
|
// Spawn 10 tasks each sending us back one int.
|
2012-03-22 10:39:41 -05:00
|
|
|
let mut i = 10;
|
2011-07-27 07:48:34 -05:00
|
|
|
while (i > 0) {
|
2011-12-22 19:53:53 -06:00
|
|
|
log(debug, i);
|
2012-07-25 16:05:06 -05:00
|
|
|
let (ch, p) = pipes::stream();
|
|
|
|
po.add(p);
|
2012-06-30 18:19:07 -05:00
|
|
|
task::spawn(|copy i| child(i, ch) );
|
2011-07-27 07:48:34 -05:00
|
|
|
i = i - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Spawned tasks are likely killed before they get a chance to send
|
|
|
|
// anything back, so we deadlock here.
|
|
|
|
|
|
|
|
i = 10;
|
|
|
|
while (i > 0) {
|
2011-12-22 19:53:53 -06:00
|
|
|
log(debug, i);
|
2012-07-25 16:05:06 -05:00
|
|
|
po.recv();
|
2011-07-27 07:48:34 -05:00
|
|
|
i = i - 1;
|
|
|
|
}
|
|
|
|
|
2012-07-30 18:01:07 -05:00
|
|
|
debug!{"main thread exiting"};
|
2011-07-27 07:48:34 -05:00
|
|
|
}
|
|
|
|
|
2012-07-25 16:05:06 -05:00
|
|
|
fn child(x: int, ch: pipes::chan<int>) {
|
2011-12-22 19:53:53 -06:00
|
|
|
log(debug, x);
|
2012-07-25 16:05:06 -05:00
|
|
|
ch.send(x);
|
2011-07-27 07:48:34 -05:00
|
|
|
}
|