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, toString
public 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 Throwable
public 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 Throwable
public void printStackTrace(PrintStream s)
printStackTrace
in class Throwable
public void printStackTrace(PrintWriter s)
printStackTrace
in class Throwable
public int size()