mirror of
				https://github.com/KevinMidboe/linguist.git
				synced 2025-10-29 17:50:22 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			76 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Scala
		
	
	
	
	
	
			
		
		
	
	
			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-
 | 
						|
 | 
						|
 | 
						|
 | 
						|
}
 |