File: pf-catch.scala

package info (click to toggle)
scala 2.11.12-5
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 62,828 kB
  • sloc: javascript: 28,808; java: 13,415; xml: 3,250; sh: 1,620; python: 756; makefile: 38; awk: 36; ansic: 6
file content (36 lines) | stat: -rw-r--r-- 887 bytes parent folder | download | duplicates (4)
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

import scala.language.{ postfixOps }
object Test {
  def shortName(x: AnyRef) = x.getClass.getName split '.' last
  type Handler[+T] = PartialFunction[Throwable, T]

  val standardHandler: Handler[String] = {
    case x: java.util.NoSuchElementException    => shortName(x)
    case x: java.lang.IllegalArgumentException  => shortName(x)
  }

  def fn[T: Handler](body: => T): T = {
    try body
    catch implicitly[Handler[T]]
  }

  def f1 = {
    implicit val myHandler = standardHandler
    println(fn(Nil.head))
    println(fn(null.toString))
  }
  def f2 = {
    implicit val myHandler: Handler[String] = standardHandler orElse {
      case x => "DEBUG: " + shortName(x)
    }
    println(fn(Nil.head))
    println(fn(null.toString))
  }

  def main(args: Array[String]): Unit = {
    try f1
    catch { case x: Throwable => println(shortName(x) + " slipped by.") }

    f2
  }
}