blob: f0b8baeeb3e1b51050ddb920c7e38e691ac158b7 (
plain) (
blame)
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
|
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 => println(shortName(x) + " slipped by.") }
f2
}
}
|