public final class CompositeException extends RuntimeException
CompositeException
does not modify the structure of any exception it wraps, but at print-time it iterates through the list of
Throwables contained in the composite in order to print them all.
Its invariant is to contain an immutable, ordered (by insertion order), unique list of non-composite
exceptions. You can retrieve individual exceptions in this list with getExceptions().
The printStackTrace() implementation handles the StackTrace in a customized way instead of using
getCause() so that it can avoid circular references.
If you invoke getCause(), it will lazily create the causal chain but will stop if it finds any
Throwable in the chain that it has already seen.| Constructor and Description |
|---|
CompositeException(Iterable<? extends Throwable> errors)
Constructs a CompositeException with the given array of Throwables as the
list of suppressed exceptions.
|
CompositeException(Throwable... exceptions)
Constructs a CompositeException with the given array of Throwables as the
list of suppressed exceptions.
|
| Modifier and Type | Method and Description |
|---|---|
Throwable |
getCause() |
List<Throwable> |
getExceptions()
Retrieves the list of exceptions that make up the
CompositeException. |
String |
getMessage() |
void |
printStackTrace()
|
void |
printStackTrace(PrintStream s) |
void |
printStackTrace(PrintWriter s) |
int |
size()
Returns the number of suppressed exceptions.
|
addSuppressed, fillInStackTrace, getLocalizedMessage, getStackTrace, getSuppressed, initCause, setStackTrace, toStringpublic CompositeException(@NonNull Throwable... exceptions)
exceptions - the Throwables to have as initially suppressed exceptionsIllegalArgumentException - if exceptions is empty.public CompositeException(@NonNull Iterable<? extends Throwable> errors)
errors - the Throwables to have as initially suppressed exceptionsIllegalArgumentException - if errors is empty.@NonNull public List<Throwable> getExceptions()
CompositeException.@NonNull public String getMessage()
getMessage in class Throwablepublic void printStackTrace()
printStackTrace functionality is derived from JDK Throwable
printStackTrace. In particular, the PrintStreamOrWriter abstraction is copied wholesale.
Changes from the official JDK implementation:PrintStream lockList that this loops throughprintStackTrace in class Throwablepublic void printStackTrace(PrintStream s)
printStackTrace in class Throwablepublic void printStackTrace(PrintWriter s)
printStackTrace in class Throwablepublic int size()