001 /** 002 * 003 * Copyright 2003-2004 The Apache Software Foundation 004 * 005 * Licensed under the Apache License, Version 2.0 (the "License"); 006 * you may not use this file except in compliance with the License. 007 * You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017 018 // 019 // This source code implements specifications defined by the Java 020 // Community Process. In order to remain compliant with the specification 021 // DO NOT add / change / or delete method signatures! 022 // 023 024 package javax.jms; 025 026 /** 027 * @version $Rev: 106434 $ $Date: 2004-11-24 09:11:30 -0800 (Wed, 24 Nov 2004) $ 028 */ 029 public class JMSException extends Exception { 030 private String errorCode; 031 032 private Exception linkedException; 033 034 public JMSException(String reason, String errorCode) { 035 super(reason); 036 this.errorCode = errorCode; 037 linkedException = null; 038 } 039 040 public JMSException(String reason) { 041 this(reason, null); 042 linkedException = null; 043 } 044 045 public String getErrorCode() { 046 return errorCode; 047 } 048 049 public Exception getLinkedException() { 050 return linkedException; 051 } 052 053 /* 054 * Although not specified in the JavaDoc, this method need to be 055 * declared synchronized to make the serialUID the same as for 056 * the RI. However, given that the setter is not synchronized 057 * this may be problematic on some platforms. 058 */ 059 public synchronized void setLinkedException(Exception ex) { 060 linkedException = ex; 061 } 062 }