summaryrefslogblamecommitdiff
path: root/docs/examples/actors/channels.scala
blob: 40ddeecbc5c5f4750d6c53775915ed0bd8abe24d (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12
13
14













                                                         


                                                     
           




                               




                 
                                    


     
package examples.actors

import scala.actors._
import scala.actors.Actor._

object channels extends Application {
  case class Msg(ch1: Channel[int], ch2: Channel[String])

  val a = actor {
    val Ch1 = new Channel[int]
    val Ch2 = new Channel[String]

    b ! Msg(Ch1, Ch2)

    val ICh1 = Ch1.asInstanceOf[InputChannel[int]]
    val ICh2 = Ch2.asInstanceOf[InputChannel[String]]

    react {
      case ICh1 ! (x: Int) =>
        val r = x + 21
        println("result: "+r)
      case ICh2 ! y =>
        println("received: "+y)
    }
  }

  val b = actor {
    react {
      case Msg(ch1, ch2) => ch1 ! 21
    }
  }
}