1. /*
  2. * The Apache Software License, Version 1.1
  3. *
  4. * Copyright (c) 1999 The Apache Software Foundation. All rights
  5. * reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. *
  11. * 1. Redistributions of source code must retain the above copyright
  12. * notice, this list of conditions and the following disclaimer.
  13. *
  14. * 2. Redistributions in binary form must reproduce the above copyright
  15. * notice, this list of conditions and the following disclaimer in
  16. * the documentation and/or other materials provided with the
  17. * distribution.
  18. *
  19. * 3. The end-user documentation included with the redistribution, if
  20. * any, must include the following acknowlegement:
  21. * "This product includes software developed by the
  22. * Apache Software Foundation (http://www.apache.org/)."
  23. * Alternately, this acknowlegement may appear in the software itself,
  24. * if and wherever such third-party acknowlegements normally appear.
  25. *
  26. * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software
  27. * Foundation" must not be used to endorse or promote products derived
  28. * from this software without prior written permission. For written
  29. * permission, please contact apache@apache.org.
  30. *
  31. * 5. Products derived from this software may not be called "Apache"
  32. * nor may "Apache" appear in their names without prior written
  33. * permission of the Apache Group.
  34. *
  35. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  36. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  37. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38. * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  39. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  41. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  42. * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  43. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  44. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  45. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  46. * SUCH DAMAGE.
  47. * ====================================================================
  48. *
  49. * This software consists of voluntary contributions made by many
  50. * individuals on behalf of the Apache Software Foundation. For more
  51. * information on the Apache Software Foundation, please see
  52. * <http://www.apache.org/>.
  53. *
  54. * ====================================================================
  55. *
  56. * This source code implements specifications defined by the Java
  57. * Community Process. In order to remain compliant with the specification
  58. * DO NOT add / change / or delete method signatures!
  59. */
  60. package javax.servlet;
  61. /**
  62. * Defines a general exception a servlet can throw when it
  63. * encounters difficulty.
  64. *
  65. * @author Various
  66. * @version $Version$
  67. *
  68. */
  69. public class ServletException extends Exception {
  70. private Throwable rootCause;
  71. /**
  72. * Constructs a new servlet exception.
  73. *
  74. */
  75. public ServletException() {
  76. super();
  77. }
  78. /**
  79. * Constructs a new servlet exception with the
  80. * specified message. The message can be written
  81. * to the server log and/or displayed for the user.
  82. *
  83. * @param message a <code>String</code>
  84. * specifying the text of
  85. * the exception message
  86. *
  87. */
  88. public ServletException(String message) {
  89. super(message);
  90. }
  91. /**
  92. * Constructs a new servlet exception when the servlet
  93. * needs to throw an exception and include a message
  94. * about the "root cause" exception that interfered with its
  95. * normal operation, including a description message.
  96. *
  97. *
  98. * @param message a <code>String</code> containing
  99. * the text of the exception message
  100. *
  101. * @param rootCause the <code>Throwable</code> exception
  102. * that interfered with the servlet's
  103. * normal operation, making this servlet
  104. * exception necessary
  105. *
  106. */
  107. public ServletException(String message, Throwable rootCause) {
  108. super(message);
  109. this.rootCause = rootCause;
  110. }
  111. /**
  112. * Constructs a new servlet exception when the servlet
  113. * needs to throw an exception and include a message
  114. * about the "root cause" exception that interfered with its
  115. * normal operation. The exception's message is based on the localized
  116. * message of the underlying exception.
  117. *
  118. * <p>This method calls the <code>getLocalizedMessage</code> method
  119. * on the <code>Throwable</code> exception to get a localized exception
  120. * message. When subclassing <code>ServletException</code>,
  121. * this method can be overridden to create an exception message
  122. * designed for a specific locale.
  123. *
  124. * @param rootCause the <code>Throwable</code> exception
  125. * that interfered with the servlet's
  126. * normal operation, making the servlet exception
  127. * necessary
  128. *
  129. */
  130. public ServletException(Throwable rootCause) {
  131. super(rootCause.getLocalizedMessage());
  132. this.rootCause = rootCause;
  133. }
  134. /**
  135. * Returns the exception that caused this servlet exception.
  136. *
  137. *
  138. * @return the <code>Throwable</code>
  139. * that caused this servlet exception
  140. *
  141. */
  142. public Throwable getRootCause() {
  143. return rootCause;
  144. }
  145. }