01: /* ====================================================================
02: The Jicarilla Software License
03:
04: Copyright (c) 2003 Leo Simons.
05: All rights reserved.
06:
07: Permission is hereby granted, free of charge, to any person obtaining
08: a copy of this software and associated documentation files (the
09: "Software"), to deal in the Software without restriction, including
10: without limitation the rights to use, copy, modify, merge, publish,
11: distribute, sublicense, and/or sell copies of the Software, and to
12: permit persons to whom the Software is furnished to do so, subject to
13: the following conditions:
14:
15: The above copyright notice and this permission notice shall be
16: included in all copies or substantial portions of the Software.
17:
18: THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19: EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20: MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
21: IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
22: CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23: TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24: SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25: ==================================================================== */
26: package org.jicarilla.container;
27:
28: import org.jicarilla.lang.CascadingRuntimeException;
29:
30: /**
31: * <p>The root exception for all of the more specific errors that are thrown by
32: * classes in the {@link org.jicarilla.container} package.</p>
33: *
34: * <p>Since this is a {@link RuntimeException}, no explicit checking for any of
35: * these exceptions needs to take place in client code if you choose not to do
36: * so. The reason all exceptions thrown by the container package are
37: * <code>RuntimeException</code>s is simple: the occurence of an exception in
38: * the container nearly always is the result of misconfiguration. Therefore, if
39: * you have done sufficient debugging, you can often choose to switch of a lot
40: * of costly exception handling in your applications.</p>
41: *
42: * @author <a href="mail at leosimons dot com">Leo Simons</a>
43: * @version $Id: JicarillaException.java,v 1.6 2004/03/23 13:37:51 lsimons Exp $
44: */
45: public class JicarillaException extends CascadingRuntimeException {
46: /**
47: * Construct a new <code>JicarillaException</code> instance.
48: */
49: public JicarillaException() {
50: super ();
51: }
52:
53: /**
54: * Construct a new <code>JicarillaException</code> instance.
55: *
56: * @param message the detail message for this exception.
57: */
58: public JicarillaException(final String message) {
59: super (message);
60: if (message == null)
61: throw new NullPointerException("message");
62: }
63:
64: /**
65: * Construct a new <code>JicarillaException</code> instance.
66: *
67: * @param throwable the root cause of the exception.
68: */
69: public JicarillaException(final Throwable throwable) {
70: super (throwable);
71: if (throwable == null)
72: throw new NullPointerException("throwable");
73: }
74:
75: /**
76: * Construct a new <code>JicarillaException</code> instance.
77: *
78: * @param message the detail message for this exception.
79: * @param throwable the root cause of the exception.
80: */
81: public JicarillaException(final String message,
82: final Throwable throwable) {
83: super (message, throwable);
84: if (message == null)
85: throw new NullPointerException("message");
86: if (throwable == null)
87: throw new NullPointerException("throwable");
88: }
89: }
|