Class NestableDelegate
- java.lang.Object
-
- org.apache.commons.lang.exception.NestableDelegate
-
- All Implemented Interfaces:
Serializable
public class NestableDelegate extends Object implements Serializable
A shared implementation of the nestable exception functionality.
The code is shared between
NestableError
,NestableException
andNestableRuntimeException
.- Since:
- 1.0
- Version:
- $Id: NestableDelegate.java 905636 2010-02-02 14:03:32Z niallp $
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static boolean
matchSubclasses
Whether to match subclasses via indexOf.static boolean
topDown
Whether to print the stack trace top-down.static boolean
trimStackFrames
Whether to trim the repeated stack trace.
-
Constructor Summary
Constructors Constructor Description NestableDelegate(Nestable nestable)
Constructs a newNestableDelegate
instance to manage the specifiedNestable
.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description String
getMessage(int index)
Returns the error message of theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.String
getMessage(String baseMsg)
Returns the full message contained by theNestable
and any nestedThrowable
s.String[]
getMessages()
Returns the error message of this and any nestedThrowable
s in an array of Strings, one element for each message.protected String[]
getStackFrames(Throwable t)
Captures the stack trace associated with the specifiedThrowable
object, decomposing it into a list of stack frames.Throwable
getThrowable(int index)
Returns theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.int
getThrowableCount()
Returns the number ofThrowable
s contained in theNestable
contained by this delegate.Throwable[]
getThrowables()
Returns this delegate'sNestable
and any nestedThrowable
s in an array ofThrowable
s, one element for eachThrowable
.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
printStackTrace()
Prints the stack trace of this exception the the standar error stream.void
printStackTrace(PrintStream out)
Prints the stack trace of this exception to the specified stream.void
printStackTrace(PrintWriter out)
Prints the stack trace of this exception to the specified writer.protected void
trimStackFrames(List stacks)
Trims the stack frames.
-
-
-
Field Detail
-
topDown
public static boolean topDown
Whether to print the stack trace top-down. This public flag may be set by calling code, typically in initialisation. This exists for backwards compatability, setting it to false will return the library to v1.0 behaviour (but will affect all users of the library in the classloader).- Since:
- 2.0
-
trimStackFrames
public static boolean trimStackFrames
Whether to trim the repeated stack trace. This public flag may be set by calling code, typically in initialisation. This exists for backwards compatability, setting it to false will return the library to v1.0 behaviour (but will affect all users of the library in the classloader).- Since:
- 2.0
-
matchSubclasses
public static boolean matchSubclasses
Whether to match subclasses via indexOf. This public flag may be set by calling code, typically in initialisation. This exists for backwards compatability, setting it to false will return the library to v2.0 behaviour (but will affect all users of the library in the classloader).- Since:
- 2.1
-
-
Method Detail
-
getMessage
public String getMessage(int index)
Returns the error message of theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.- 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 - Throws:
IndexOutOfBoundsException
- if theindex
argument is negative or not less than the count ofThrowable
s in the chain- Since:
- 2.0
-
getMessage
public String getMessage(String baseMsg)
Returns the full message contained by theNestable
and any nestedThrowable
s.- Parameters:
baseMsg
- the base message to use when creating the full message. Should be generally be called vianestableHelper.getMessage(super.getMessage())
, wheresuper
is an instance ofThrowable
.- Returns:
- The concatenated message for this and all nested
Throwable
s - Since:
- 2.0
-
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 thegetThrowableCount()
operation.- Returns:
- the error messages
- Since:
- 2.0
-
getThrowable
public Throwable getThrowable(int index)
Returns theThrowable
in the chain ofThrowable
s at the specified index, numbered from 0.- Parameters:
index
- the index, numbered from 0, of theThrowable
in the chain ofThrowable
s- Returns:
- the
Throwable
- Throws:
IndexOutOfBoundsException
- if theindex
argument is negative or not less than the count ofThrowable
s in the chain- Since:
- 2.0
-
getThrowableCount
public int getThrowableCount()
Returns the number ofThrowable
s contained in theNestable
contained by this delegate.- Returns:
- the throwable count
- Since:
- 2.0
-
getThrowables
public Throwable[] getThrowables()
Returns this delegate'sNestable
and any nestedThrowable
s in an array ofThrowable
s, one element for eachThrowable
.- Returns:
- the
Throwable
s - Since:
- 2.0
-
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). An alternative is to use the public static flagmatchSubclasses
onNestableDelegate
, however this is not recommended.- 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
- Throws:
IndexOutOfBoundsException
- if thefromIndex
argument is negative or not less than the count ofThrowable
s in the chain- Since:
- 2.0
-
printStackTrace
public void printStackTrace()
Prints the stack trace of this exception the the standar error stream.
-
printStackTrace
public void printStackTrace(PrintStream out)
Prints the stack trace of this exception to the specified stream.- Parameters:
out
-PrintStream
to use for output.- See Also:
printStackTrace(PrintWriter)
-
printStackTrace
public void printStackTrace(PrintWriter out)
Prints the stack trace of this exception to the specified writer. If the Throwable class has agetCause
method (i.e. running on jre1.4 or higher), this method just uses Throwable's printStackTrace() method. Otherwise, generates the stack-trace, by taking into account the 'topDown' and 'trimStackFrames' parameters. The topDown and trimStackFrames are set to 'true' by default (produces jre1.4-like stack trace).- Parameters:
out
-PrintWriter
to use for output.
-
getStackFrames
protected String[] getStackFrames(Throwable t)
Captures the stack trace associated with the specifiedThrowable
object, decomposing it into a list of stack frames.- Parameters:
t
- TheThrowable
.- Returns:
- An array of strings describing each stack frame.
- Since:
- 2.0
-
trimStackFrames
protected void trimStackFrames(List stacks)
Trims the stack frames. The first set is left untouched. The rest of the frames are truncated from the bottom by comparing with one just on top.- Parameters:
stacks
- The list containing String[] elements- Since:
- 2.0
-
-