]> git.lizzy.rs Git - rust.git/commitdiff
doc: Fix deadlocks in tutorial due to yield bustage
authorBrian Anderson <banderson@mozilla.com>
Tue, 6 Aug 2013 20:25:09 +0000 (13:25 -0700)
committerBrian Anderson <banderson@mozilla.com>
Wed, 7 Aug 2013 23:32:20 +0000 (16:32 -0700)
doc/tutorial-tasks.md

index b5677a261c45bffd12d1d80907e3df7ed035f45f..d9e4b9b399d2c623309e8d88cc479d867abdc11f 100644 (file)
@@ -492,7 +492,8 @@ either task fails, it kills the other one.
 
 ~~~
 # use std::task;
-# fn sleep_forever() { loop { task::yield() } }
+# use std::comm::oneshot;
+# fn sleep_forever() { loop { let (p, c) = oneshot::<()>(); p.recv(); } }
 # do task::try {
 do spawn {
     do spawn {
@@ -513,9 +514,10 @@ before returning. Hence:
 
 ~~~
 # use std::comm::{stream, Chan, Port};
+# use std::comm::oneshot;
 # use std::task::{spawn, try};
 # use std::task;
-# fn sleep_forever() { loop { task::yield() } }
+# fn sleep_forever() { loop { let (p, c) = oneshot::<()>(); p.recv(); } }
 # do task::try {
 let (receiver, sender): (Port<int>, Chan<int>) = stream();
 do spawn {  // Bidirectionally linked
@@ -543,7 +545,8 @@ an intermediate generation has already exited:
 
 ~~~
 # use std::task;
-# fn sleep_forever() { loop { task::yield() } }
+# use std::comm::oneshot;
+# fn sleep_forever() { loop { let (p, c) = oneshot::<()>(); p.recv(); } }
 # fn wait_for_a_while() { for _ in range(0, 1000u) { task::yield() } }
 # do task::try::<int> {
 do task::spawn_supervised {