Package org.codehaus.groovy.runtime
Class StackTraceUtils
- java.lang.Object
-
- org.codehaus.groovy.runtime.StackTraceUtils
-
public class StackTraceUtils extends Object
Originally was grails.utils.GrailsUtils, removed some grails specific stuff. Utility methods removing internal lines from stack traces- Since:
- 1.5
-
-
Field Summary
Fields Modifier and Type Field Description static String
STACK_LOG_NAME
-
Constructor Summary
Constructors Constructor Description StackTraceUtils()
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static void
addClassTest(Closure test)
Adds a groovy.lang.Closure to test whether the stack trace element should be added or not.static Throwable
deepSanitize(Throwable t)
Sanitize the exception and ALL nested causesstatic Throwable
extractRootCause(Throwable t)
Extracts the root cause of the exception, no matter how nested it isstatic boolean
isApplicationClass(String className)
static void
printSanitizedStackTrace(Throwable t)
static void
printSanitizedStackTrace(Throwable t, PrintWriter p)
static Throwable
sanitize(Throwable t)
Remove all apparently groovy-internal trace entries from the exception instancestatic Throwable
sanitizeRootCause(Throwable t)
Get the root cause of an exception and sanitize it for display to the user
-
-
-
Field Detail
-
STACK_LOG_NAME
public static final String STACK_LOG_NAME
- See Also:
- Constant Field Values
-
-
Method Detail
-
addClassTest
public static void addClassTest(Closure test)
Adds a groovy.lang.Closure to test whether the stack trace element should be added or not.The groovy.lang.Closure will be given the class name as parameter. the return value decides if the element will be added or not.
- true - trace element will be added to the trace
- false - trace element will not be added to the trace
- null - continue with next test
- Parameters:
test
- the testing groovy.lang.Closure
-
sanitize
public static Throwable sanitize(Throwable t)
Remove all apparently groovy-internal trace entries from the exception instanceThis modifies the original instance and returns it, it does not clone
- Parameters:
t
- the Throwable whose stack trace we want to sanitize- Returns:
- The original Throwable but with a sanitized stack trace
-
printSanitizedStackTrace
public static void printSanitizedStackTrace(Throwable t, PrintWriter p)
-
printSanitizedStackTrace
public static void printSanitizedStackTrace(Throwable t)
-
isApplicationClass
public static boolean isApplicationClass(String className)
-
extractRootCause
public static Throwable extractRootCause(Throwable t)
Extracts the root cause of the exception, no matter how nested it is- Parameters:
t
- a Throwable- Returns:
- The deepest cause of the exception that can be found
-
sanitizeRootCause
public static Throwable sanitizeRootCause(Throwable t)
Get the root cause of an exception and sanitize it for display to the userThis will MODIFY the stacktrace of the root cause exception object and return it
- Parameters:
t
- a throwable- Returns:
- The root cause exception instance, with its stace trace modified to filter out groovy runtime classes
-
deepSanitize
public static Throwable deepSanitize(Throwable t)
Sanitize the exception and ALL nested causesThis will MODIFY the stacktrace of the exception instance and all its causes irreversibly
- Parameters:
t
- a throwable- Returns:
- The root cause exception instances, with stack trace modified to filter out groovy runtime classes
-
-