2012-04-03 16:03:27 -05:00
|
|
|
// Jump back and forth between the OS main thread and a new scheduler.
|
|
|
|
// The OS main scheduler should continue to be available and not terminate
|
|
|
|
// while it is not in use.
|
|
|
|
|
|
|
|
fn main() {
|
2012-04-03 19:39:35 -05:00
|
|
|
run(100);
|
2012-04-03 16:03:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn run(i: int) {
|
|
|
|
|
|
|
|
log(debug, i);
|
|
|
|
|
|
|
|
if i == 0 {
|
|
|
|
ret;
|
|
|
|
}
|
|
|
|
|
2012-07-23 18:58:47 -05:00
|
|
|
do task::task().sched_mode(task::osmain).unlinked().spawn {
|
2012-04-03 16:03:27 -05:00
|
|
|
task::yield();
|
2012-07-23 18:58:47 -05:00
|
|
|
do task::task().sched_mode(task::single_threaded).unlinked().spawn {
|
2012-04-03 16:03:27 -05:00
|
|
|
task::yield();
|
|
|
|
run(i - 1);
|
|
|
|
task::yield();
|
|
|
|
}
|
|
|
|
task::yield();
|
|
|
|
}
|
|
|
|
}
|