Exception Helper : Exceptions « Language Basics « Java






Exception Helper

        
/*  
 * Copyright 2008-2010 the original author or authors 
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
//package org.kaleidofoundry.core.util;

import java.io.PrintWriter;
import java.io.StringWriter;
import java.lang.reflect.Method;

/**
 * Exception Helper
 * 
 * @author Jerome RADUGET
 */
public abstract class ThrowableHelper {

  // Get javax.servlet.ServletException dynamically if no web container in
  // classpath (no need to have servlet.jar in classpath)
  final static Class<?> ServletExceptionClass;

  static {
    Class<?> servletExceptionClass = null;
    try {
      servletExceptionClass = Class
          .forName("javax.servlet.ServletException");
    } catch (final Throwable th) {
    }
    ServletExceptionClass = servletExceptionClass;
  }

  /**
   * @param th
   * @return the string representation of an exception stack trace
   */
  public static String getStackTrace(final Throwable th) {

    final StringWriter writer = new StringWriter();
    final PrintWriter pw = new PrintWriter(writer);
    fillStackTrace(th, pw);

    return writer.toString();
  }

  /*
   * @param ex
   * 
   * @param pw
   */
  private static void fillStackTrace(final Throwable ex, final PrintWriter pw) {

    if (ex == null) {
      pw.print("");
      return;
    }

    // exception stack trace
    ex.printStackTrace(pw);

    // servlet exception root cause
    if (ServletExceptionClass != null
        && ex.getClass().isAssignableFrom(ServletExceptionClass)) {
      try {
        final Method getRootCauseMethod = ex.getClass().getMethod(
            "getRootCause");
        final Throwable cause = (Throwable) getRootCauseMethod.invoke(
            ex, new Object[] {});
        if (null != cause) {
          pw.println("Root Cause:");
          fillStackTrace(cause, pw);
          return;
        }
      } catch (final Throwable th) {
      }
    }

    // otherwise
    final Throwable cause = ex.getCause();
    if (null != cause) {
      pw.println("Cause:");
      fillStackTrace(cause, pw);
    }

  }
}

   
    
    
    
    
    
    
    
  








Related examples in the same category

1.Illustrate various Exceptions Illustrate various Exceptions
2.Experience exceptionsExperience exceptions
3.StackTrace
4.Getting the Stack Trace of an Exception
5.What happens if a method declares an unchecked exception?
6.Simple demo of exceptionsSimple demo of exceptions
7.Simple demo of exceptions, with finally clauseSimple demo of exceptions, with finally clause
8.ThreadBasedCatcher - Demonstrate catching uncaught exceptions
9.Exception CatcherException Catcher
10.Turning off Checked exceptions
11.Demonstrates exception chainingDemonstrates exception chaining
12.Finally is always executedFinally is always executed
13.Demonstrating the Exception MethodsDemonstrating the Exception Methods
14.Further embellishment of exception classesFurther embellishment of exception classes
15.The finally clause is always executedThe finally clause is always executed
16.Your own Exception classYour own Exception class
17.Catching exception hierarchiesCatching exception hierarchies
18.How an exception can be lost
19.Exception in main method
20.Ignoring RuntimeExceptionsIgnoring RuntimeExceptions
21.Demonstrating fillInStackTrace()Demonstrating fillInStackTrace()
22.Put printStackTrace() into a String: redirect the StackTrace to a String with a StringWriter/PrintWriter
23.Rethrow a different object from the one that was caughtRethrow a different object from the one that was caught
24.Inheriting your own exceptionsInheriting your own exceptions
25.Overridden methods may throw only the exceptions
26.Returns the output of printStackTrace as a String.
27.Locates a particular type of exception
28.Throw Exception OutThrow Exception Out
29.Get Deepest ThrowableGet Deepest Throwable
30.Make a string representation of the exception
31.Utility methods for dealing with stack traces
32.Returns the root cause of an exception
33.Utility class to work with throwables
34.Print all of the thread's information and stack traces
35.Convert an exception to a String with full stack trace
36.Return stack trace from the passed exception as a stringReturn stack trace from the passed exception as a string
37.Create a new RuntimeException, setting the cause if possible.
38.Create a new Exception, setting the cause if possible.
39.Set the cause of the Exception. Will detect if this is not allowed.
40.Get the stack trace of the supplied exception.
41.Display Stack Trace Information with StackTraceElement
42.A collection of utility methods for manipulating exceptions
43.A frame with a panel for testing various exceptionsA frame with a panel for testing various exceptions
44.Convert Throwable to string
45.Convert the result of Exception.getStackTrace to a String
46.Prints the stack trace of the specified throwable to a string and returns it.
47.Get Stack Trace Element
48.Get stack trace and cause exception
49.Exception Util