Files
linguist/samples/Scala/node11.sc
2013-12-11 15:06:14 -08:00

76 lines
3.2 KiB
Scala

import math.random
import scala.language.postfixOps
import scala.util._
import scala.util.{Try, Success, Failure}
import scala.concurrent._
import duration._
import ExecutionContext.Implicits.global
import scala.concurrent.{ ExecutionContext, CanAwait, OnCompleteRunnable, TimeoutException, ExecutionException, blocking }
/* This worksheet demonstrates some of the code snippets from
* Week3, Lecture 4, "Composing Futures".
*/
object node11 {
println("Welcome to the Scala worksheet") //> Welcome to the Scala worksheet
/**
* Retry successfully completing block at most noTimes
* and give up after that
*/
def retry[T](n: Int)(block: =>Future[T]): Future[T] = {
val ns: Iterator[Int] = (1 to n).iterator
val attempts: Iterator[()=>Future[T]] = ns.map(_ => ()=>block)
val failed: Future[T] = Future.failed(new Exception)
attempts.foldLeft(failed)((a, block) => a fallbackTo { block() })
} //> retry: [T](n: Int)(block: => scala.concurrent.Future[T])scala.concurrent.Fut
//| ure[T]
def rb(i: Int) = {
blocking{Thread.sleep(100*random.toInt)}
println("Hi " ++ i.toString)
i + 10
} //> rb: (i: Int)Int
def block(i: Int) = {
println("Iteration: " + i.toString)
val ri = retry(i)( Future {rb(i)} )
ri onComplete {
case Success(s) => println(s.toString ++ " = 10 + " ++ i.toString)
case Failure(t:Exception) => println(t.toString ++ " " ++ i.toString)
case r => println(r.toString ++ " " ++ i.toString)
}
} //> block: (i: Int)Unit
/* Multiple executions of a block of commands where
* each block contains one collectCoins and
* one buyTreasure. If either call fails, the whole iteration does not fail,
* because we are catching exceptions (with flatMap) in this implementation.
* Note that these blocks execute synchrounsly.
*/
(0 to 4 toList).foreach(i =>block(i)) //> Iteration: 0
//| Iteration: 1
//| java.lang.Exception 0
//| Hi 1
//| Iteration: 2
//| 11 = 10 + 1
//| Hi 2
//| Iteration: 3
//| Hi 3
//| Hi 2
//| Iteration: 4
//| 12 = 10 + 2
blocking{Thread.sleep(3000)} //> Hi 4
//| Hi 3
//| 13 = 10 + 3
//| Hi 3
//| 14 = 10 + 4
//| Hi 4
//| Hi 4
//| Hi 4-
}