Class NestableRuntimeException
- java.lang.Object
-
- java.lang.Throwable
-
- java.lang.Exception
-
- java.lang.RuntimeException
-
- org.apache.commons.lang.exception.NestableRuntimeException
-
- All Implemented Interfaces:
Serializable
,Nestable
- Direct Known Subclasses:
CloneFailedException
,SerializationException
,UnhandledException
public class NestableRuntimeException extends RuntimeException implements Nestable
The base class of all runtime exceptions which can contain other exceptions.- Since:
- 1.0
- Version:
- $Id: NestableRuntimeException.java 512889 2007-02-28 18:18:20Z dlr $
- See Also:
NestableException
, Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected NestableDelegate
delegate
The helper instance which contains much of the code which we delegate to.
-
Constructor Summary
Constructors Constructor Description NestableRuntimeException()
Constructs a newNestableRuntimeException
without specified detail message.NestableRuntimeException(String msg)
Constructs a newNestableRuntimeException
with specified detail message.NestableRuntimeException(String msg, Throwable cause)
Constructs a newNestableRuntimeException
with specified detail message and nestedThrowable
.NestableRuntimeException(Throwable cause)
Constructs a newNestableRuntimeException
with specified nestedThrowable
.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Throwable
getCause()
Returns the reference to the exception or error that caused the exception implementing theNestable
to be thrown.String
getMessage()
Returns the detail message string of this throwable.String
getMessage(int index)
Returns the error message of theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.String[]
getMessages()
Returns the error message of this and any nestedThrowable
s in an array of Strings, one element for each message.Throwable
getThrowable(int index)
Returns theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.int
getThrowableCount()
Returns the number of nestedThrowable
s represented by thisNestable
, including thisNestable
.Throwable[]
getThrowables()
Returns thisNestable
and any nestedThrowable
s in an array ofThrowable
s, one element for eachThrowable
.int
indexOfThrowable(Class type)
Returns the index, numbered from 0, of the first occurrence of the specified type, or a subclass, in the chain ofThrowable
s.int
indexOfThrowable(Class type, int fromIndex)
Returns the index, numbered from 0, of the firstThrowable
that matches the specified type, or a subclass, in the chain ofThrowable
s with an index greater than or equal to the specified index.void
printPartialStackTrace(PrintWriter out)
Prints the stack trace for this exception only--root cause not included--using the provided writer.void
printStackTrace()
void
printStackTrace(PrintStream out)
Prints the stack trace of this exception to the specified print stream.void
printStackTrace(PrintWriter out)
Prints the stack trace of this exception to the specified print writer.-
Methods inherited from class java.lang.Throwable
addSuppressed, fillInStackTrace, getLocalizedMessage, getStackTrace, getSuppressed, initCause, setStackTrace, toString
-
-
-
-
Field Detail
-
delegate
protected NestableDelegate delegate
The helper instance which contains much of the code which we delegate to.
-
-
Constructor Detail
-
NestableRuntimeException
public NestableRuntimeException()
Constructs a newNestableRuntimeException
without specified detail message.
-
NestableRuntimeException
public NestableRuntimeException(String msg)
Constructs a newNestableRuntimeException
with specified detail message.- Parameters:
msg
- the error message
-
NestableRuntimeException
public NestableRuntimeException(Throwable cause)
Constructs a newNestableRuntimeException
with specified nestedThrowable
.- Parameters:
cause
- the exception or error that caused this exception to be thrown
-
-
Method Detail
-
getCause
public Throwable getCause()
Returns the reference to the exception or error that caused the exception implementing theNestable
to be thrown.
-
getMessage
public String getMessage()
Returns the detail message string of this throwable. If it was created with a null message, returns the following: (cause==null ? null : cause.toString()).- Specified by:
getMessage
in interfaceNestable
- Overrides:
getMessage
in classThrowable
- Returns:
- String message string of the throwable
-
getMessage
public String getMessage(int index)
Returns the error message of theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.- Specified by:
getMessage
in interfaceNestable
- Parameters:
index
- the index of theThrowable
in the chain ofThrowable
s- Returns:
- the error message, or null if the
Throwable
at the specified index in the chain does not contain a message
-
getMessages
public String[] getMessages()
Returns the error message of this and any nestedThrowable
s in an array of Strings, one element for each message. AnyThrowable
not containing a message is represented in the array by a null. This has the effect of cause the length of the returned array to be equal to the result of theNestable.getThrowableCount()
operation.- Specified by:
getMessages
in interfaceNestable
- Returns:
- the error messages
-
getThrowable
public Throwable getThrowable(int index)
Returns theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.- Specified by:
getThrowable
in interfaceNestable
- Parameters:
index
- the index, numbered from 0, of theThrowable
in the chain ofThrowable
s- Returns:
- the
Throwable
-
getThrowableCount
public int getThrowableCount()
Returns the number of nestedThrowable
s represented by thisNestable
, including thisNestable
.- Specified by:
getThrowableCount
in interfaceNestable
- Returns:
- the throwable count
-
getThrowables
public Throwable[] getThrowables()
Returns thisNestable
and any nestedThrowable
s in an array ofThrowable
s, one element for eachThrowable
.- Specified by:
getThrowables
in interfaceNestable
- Returns:
- the
Throwable
s
-
indexOfThrowable
public int indexOfThrowable(Class type)
Returns the index, numbered from 0, of the first occurrence of the specified type, or a subclass, in the chain ofThrowable
s. The method returns -1 if the specified type is not found in the chain.NOTE: From v2.1, we have clarified the
Nestable
interface such that this method matches subclasses. If you want to NOT match subclasses, please useExceptionUtils.indexOfThrowable(Throwable, Class)
(which is avaiable in all versions of lang).- Specified by:
indexOfThrowable
in interfaceNestable
- Parameters:
type
- the type to find, subclasses match, null returns -1- Returns:
- index of the first occurrence of the type in the chain, or -1 if the type is not found
-
indexOfThrowable
public int indexOfThrowable(Class type, int fromIndex)
Returns the index, numbered from 0, of the firstThrowable
that matches the specified type, or a subclass, in the chain ofThrowable
s with an index greater than or equal to the specified index. The method returns -1 if the specified type is not found in the chain.NOTE: From v2.1, we have clarified the
Nestable
interface such that this method matches subclasses. If you want to NOT match subclasses, please useExceptionUtils.indexOfThrowable(Throwable, Class, int)
(which is avaiable in all versions of lang).- Specified by:
indexOfThrowable
in interfaceNestable
- Parameters:
type
- the type to find, subclasses match, null returns -1fromIndex
- the index, numbered from 0, of the starting position in the chain to be searched- Returns:
- index of the first occurrence of the type in the chain, or -1 if the type is not found
-
printStackTrace
public void printStackTrace()
- Overrides:
printStackTrace
in classThrowable
-
printStackTrace
public void printStackTrace(PrintStream out)
Prints the stack trace of this exception to the specified print stream. Includes information from the exception, if any, which caused this exception.- Specified by:
printStackTrace
in interfaceNestable
- Overrides:
printStackTrace
in classThrowable
- Parameters:
out
-PrintStream
to use for output.
-
printStackTrace
public void printStackTrace(PrintWriter out)
Prints the stack trace of this exception to the specified print writer. Includes information from the exception, if any, which caused this exception.- Specified by:
printStackTrace
in interfaceNestable
- Overrides:
printStackTrace
in classThrowable
- Parameters:
out
-PrintWriter
to use for output.
-
printPartialStackTrace
public final void printPartialStackTrace(PrintWriter out)
Prints the stack trace for this exception only--root cause not included--using the provided writer. Used byNestableDelegate
to write individual stack traces to a buffer. The implementation of this method should callsuper.printStackTrace(out);
in most cases.- Specified by:
printPartialStackTrace
in interfaceNestable
- Parameters:
out
- The writer to use.
-
-