- /*
- * @(#)CertPathBuilderException.java 1.4 03/01/23
- *
- * Copyright 2003 Sun Microsystems, Inc. All rights reserved.
- * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- */
- package java.security.cert;
- import java.io.PrintStream;
- import java.io.PrintWriter;
- /**
- * An exception indicating one of a variety of problems encountered when
- * building a certification path with a <code>CertPathBuilder</code>.
- * <p>
- * A <code>CertPathBuilderException</code> provides support for wrapping
- * exceptions. The {@link #getCause getCause} method returns the throwable,
- * if any, that caused this exception to be thrown.
- * <p>
- * <b>Concurrent Access</b>
- * <p>
- * Unless otherwise specified, the methods defined in this class are not
- * thread-safe. Multiple threads that need to access a single
- * object concurrently should synchronize amongst themselves and
- * provide the necessary locking. Multiple threads each manipulating
- * separate objects need not synchronize.
- *
- * @see CertPathBuilder
- *
- * @version 1.4 01/23/03
- * @since 1.4
- * @author Sean Mullan
- */
- public class CertPathBuilderException extends
- java.security.GeneralSecurityException {
- /**
- * Creates a <code>CertPathBuilderException</code> with <code>null</code>
- * as its detail message.
- */
- public CertPathBuilderException() {
- super();
- }
- /**
- * Creates a <code>CertPathBuilderException</code> with the given
- * detail message. The detail message is a <code>String</code> that
- * describes this particular exception in more detail.
- *
- * @param msg the detail message
- */
- public CertPathBuilderException(String msg) {
- super(msg);
- }
- /**
- * Creates a <code>CertPathBuilderException</code> that wraps the specified
- * throwable. This allows any exception to be converted into a
- * <code>CertPathBuilderException</code>, while retaining information
- * about the wrapped exception, which may be useful for debugging. The
- * detail message is set to (<code>cause==null ? null : cause.toString()
- * </code>) (which typically contains the class and detail message of
- * cause).
- *
- * @param cause the cause (which is saved for later retrieval by the
- * {@link #getCause getCause()} method). (A <code>null</code> value is
- * permitted, and indicates that the cause is nonexistent or unknown.)
- */
- public CertPathBuilderException(Throwable cause) {
- super();
- initCause(cause);
- }
- /**
- * Creates a <code>CertPathBuilderException</code> with the specified
- * detail message and cause.
- *
- * @param msg the detail message
- * @param cause the cause (which is saved for later retrieval by the
- * {@link #getCause getCause()} method). (A <code>null</code> value is
- * permitted, and indicates that the cause is nonexistent or unknown.)
- */
- public CertPathBuilderException(String msg, Throwable cause) {
- super(msg);
- initCause(cause);
- }
- /**
- * Returns the internal (wrapped) cause, or <code>null</code>
- * if the cause is nonexistent or unknown.
- *
- * @return the cause of this throwable or <code>null</code> if the cause
- * is nonexistent or unknown.
- */
- public Throwable getCause() {
- return super.getCause();
- }
- /**
- * Returns the detail message for this
- * <code>CertPathBuilderException</code>.
- *
- * @return the detail message, or <code>null</code> if neither the message
- * nor internal cause were specified
- */
- public String getMessage() {
- return super.getMessage();
- }
- /**
- * Returns a string describing this exception, including a description
- * of the internal (wrapped) cause if there is one.
- *
- * @return a string representation of this
- * <code>CertPathBuilderException</code>
- */
- public String toString() {
- if (getCause() == null)
- return super.toString();
- else
- return super.toString() +
- "; internal cause is: \n\t" +
- getCause().toString();
- }
- /**
- * Prints a stack trace to <code>System.err</code>, including the backtrace
- * of the cause, if any.
- */
- public void printStackTrace() {
- printStackTrace(System.err);
- }
- /**
- * Prints a stack trace to a <code>PrintStream</code>, including the
- * backtrace of the cause, if any.
- *
- * @param ps the <code>PrintStream</code> to use for output
- */
- public void printStackTrace(PrintStream ps) {
- super.printStackTrace(ps);
- }
- /**
- * Prints a stack trace to a <code>PrintWriter</code>, including the
- * backtrace of the cause, if any.
- *
- * @param pw the <code>PrintWriter</code> to use for output
- */
- public void printStackTrace(PrintWriter pw) {
- super.printStackTrace(pw);
- }
- }