All Downloads are FREE. Search and download functionalities are using the official Maven repository.

patterntesting.runtime.exception.NotFoundException Maven / Gradle / Ivy

/*
 * $Id: NotFoundException.java,v 1.3 2016/01/06 20:46:32 oboehm Exp $
 *
 * Copyright (c) 2013 by Oliver Boehm
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express orimplied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * (c)reated 11.11.2013 by oliver ([email protected])
 */

package patterntesting.runtime.exception;

import java.util.NoSuchElementException;

/**
 * If you did not find a result and want to avoid 'null" as return value you can
 * throw this exception here. Since 1.5 it is no longer derived direct from
 * {@link RuntimeException} but {@link NoSuchElementException}. The reason for
 * this change is a missing constructor like
 * {@link NotFoundException#NotFoundException(String, Throwable)} in
 * {@link NoSuchElementException}.
 *
 * @author oliver
 * @see RuntimeException
 * @since 1.4 (11.11.2013)
 */
public class NotFoundException extends NoSuchElementException {

    private static final long serialVersionUID = 20140818L;
    private final Throwable cause;

    /**
     * Instantiates a new not found exception.
     *
     * @param notFound the object which was not found
     */
    public NotFoundException(final Object notFound) {
        this("not found: " + notFound);
    }

    /**
     * Instantiates a new not found exception.
     *
     * @param msg the msg
     */
    public NotFoundException(final String msg) {
        this(msg, null);
    }

    /**
     * Instantiates a new not found exception.
     *
     * @param t the cause
     */
    public NotFoundException(final Throwable t) {
        super();
        this.cause = t;
    }

    /**
     * Instantiates a new not found exception.
     *
     * @param msg the msg
     * @param t the cause
     */
    public NotFoundException(final String msg, final Throwable t) {
        super(msg);
        this.cause = t;
    }

    /**
     * Gets the stored cause.
     *
     * @return the cause
     * @see java.lang.Throwable#getCause()
     */
    @Override
    public Throwable getCause() {
        return this.cause;
    }

}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy