001 /* 002 * Licensed to the Apache Software Foundation (ASF) under one or more 003 * contributor license agreements. See the NOTICE file distributed with 004 * this work for additional information regarding copyright ownership. 005 * The ASF licenses this file to You under the Apache License, Version 2.0 006 * (the "License"); you may not use this file except in compliance with 007 * the License. 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 package org.apache.commons.io; 019 020 import java.io.IOException; 021 022 /** 023 * Subclasses IOException with the {@link Throwable} constructors missing before Java 6. If you are using Java 6, 024 * consider this class deprecated and use {@link IOException}. 025 * 026 * @author <a href="http://commons.apache.org/io/">Apache Commons IO</a> 027 * @version $Id: IOExceptionWithCause.java 651569 2008-04-25 10:42:55Z niallp $ 028 * @since Commons IO 1.4 029 */ 030 public class IOExceptionWithCause extends IOException { 031 032 /** 033 * Defines the serial version UID. 034 */ 035 private static final long serialVersionUID = 1L; 036 037 /** 038 * Constructs a new instance with the given message and cause. 039 * <p> 040 * As specified in {@link Throwable}, the message in the given <code>cause</code> is not used in this instance's 041 * message. 042 * </p> 043 * 044 * @param message 045 * the message (see {@link #getMessage()}) 046 * @param cause 047 * the cause (see {@link #getCause()}). A <code>null</code> value is allowed. 048 */ 049 public IOExceptionWithCause(String message, Throwable cause) { 050 super(message); 051 this.initCause(cause); 052 } 053 054 /** 055 * Constructs a new instance with the given cause. 056 * <p> 057 * The message is set to <code>cause==null ? null : cause.toString()</code>, which by default contains the class 058 * and message of <code>cause</code>. This constructor is useful for call sites that just wrap another throwable. 059 * </p> 060 * 061 * @param cause 062 * the cause (see {@link #getCause()}). A <code>null</code> value is allowed. 063 */ 064 public IOExceptionWithCause(Throwable cause) { 065 super(cause == null ? null : cause.toString()); 066 this.initCause(cause); 067 } 068 069 }