File: reactor-exceptionOnSend.scala

package info (click to toggle)
scala 2.9.2%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 67,252 kB
  • ctags: 6,602
  • sloc: java: 27,488; xml: 4,412; python: 2,297; sh: 734; makefile: 16; ansic: 6
file content (55 lines) | stat: -rw-r--r-- 1,059 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import scala.actors.Reactor
import scala.actors.Actor._

case class MyException(text: String) extends Exception(text)

object A extends Reactor[Any] {
  override def exceptionHandler = {
    case MyException(text) =>
      println("receiver handles exception")
  }

  def guard(): Boolean =
    if (state == 0) {
      state = 1
      throw MyException("illegal state")
    } else
      true

  var state = 0

  def act() {
    try {
    loop {
      react {
        case 'hello if guard() =>
          println("process")
          exit()
      }
    }
    } catch {
      case e: Throwable if (!e.isInstanceOf[scala.util.control.ControlThrowable] &&
                            !e.isInstanceOf[MyException]) =>
        e.printStackTrace()
    }
  }
}

object B extends Reactor[Any] {
  def act() {
    try {
    A.start()
    A ! 'hello
    A ! 'hello
    } catch {
      case e: Throwable if !e.isInstanceOf[scala.util.control.ControlThrowable] =>
        e.printStackTrace()
    }
  }
}

object Test {
  def main(args: Array[String]) {
    B.start()
  }
}