blob: 64afb1f10f64841ae9e9d7d917a3a9b73a6d2702 (
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
|
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2003-2011, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package scala.util.control
/** A marker trait indicating that the `Throwable` it is mixed into is
* intended for flow control.
*
* Note that `Throwable` subclasses which extend this trait may extend any
* other `Throwable` subclass (eg. `RuntimeException`) and are not required
* to extend `Throwable` directly.
*
* Instances of `Throwable` subclasses marked in this way should not normally
* be caught. Where catch-all behaviour is required `ControlThrowable`
* should be propagated, for example:
* {{{
* import scala.util.control.ControlThrowable
*
* try {
* // Body might throw arbitrarily
* } catch {
* case c: ControlThrowable => throw c // propagate
* case t: Exception => log(t) // log and suppress
* }
* }}}
*
* @author Miles Sabin
*/
trait ControlThrowable extends Throwable with NoStackTrace
|