blob: 86dceeff2559cc772454b848e4d16616a57d22c3 (
plain)
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
|
package org.junit.internal;
/**
* Miscellaneous functions dealing with {@code Throwable}.
*
* @author kcooney@google.com (Kevin Cooney)
* @since 4.12
*/
public final class Throwables {
private Throwables() {
}
/**
* Rethrows the given {@code Throwable}, allowing the caller to
* declare that it throws {@code Exception}. This is useful when
* your callers have nothing reasonable they can do when a
* {@code Throwable} is thrown. This is declared to return {@code Exception}
* so it can be used in a {@code throw} clause:
* <pre>
* try {
* doSomething();
* } catch (Throwable e} {
* throw Throwables.rethrowAsException(e);
* }
* doSomethingLater();
* </pre>
*
* @param e exception to rethrow
* @return does not return anything
* @since 4.12
*/
public static Exception rethrowAsException(Throwable e) throws Exception {
Throwables.<Exception>rethrow(e);
return null; // we never get here
}
@SuppressWarnings("unchecked")
private static <T extends Throwable> void rethrow(Throwable e) throws T {
throw (T) e;
}
}
|