138 lines
4.3 KiB
Java
Raw Normal View History

2010-02-08 15:30:06 +02:00
/*
* Licensed to Elastic Search and Shay Banon under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. Elastic Search licenses this
* file to you 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 or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.elasticsearch;
/**
2010-02-13 20:03:37 +02:00
* A base class for all elasticsearch exceptions.
*
* @author kimchy (Shay Banon)
2010-02-08 15:30:06 +02:00
*/
public class ElasticSearchException extends RuntimeException {
/**
2010-02-13 20:03:37 +02:00
* Construct a <code>ElasticSearchException</code> with the specified detail message.
2010-02-08 15:30:06 +02:00
*
* @param msg the detail message
*/
public ElasticSearchException(String msg) {
super(msg);
}
/**
2010-02-13 20:03:37 +02:00
* Construct a <code>ElasticSearchException</code> with the specified detail message
2010-02-08 15:30:06 +02:00
* and nested exception.
*
* @param msg the detail message
* @param cause the nested exception
*/
public ElasticSearchException(String msg, Throwable cause) {
super(msg, cause);
}
2010-02-13 20:03:37 +02:00
/**
* Unwraps the actual cause from the exception for cases when the exception is a
* {@link ElasticSearchWrapperException}.
*
* @see org.elasticsearch.ExceptionsHelper#unwrapCause(Throwable)
*/
2010-02-08 15:30:06 +02:00
public Throwable unwrapCause() {
return ExceptionsHelper.unwrapCause(this);
}
/**
* Return the detail message, including the message from the nested exception
* if there is one.
*/
public String getDetailedMessage() {
if (getCause() != null) {
StringBuilder sb = new StringBuilder();
if (super.getMessage() != null) {
sb.append(super.getMessage()).append("; ");
}
sb.append("nested exception is ").append(getCause());
return sb.toString();
} else {
return super.getMessage();
}
}
/**
* Retrieve the innermost cause of this exception, if any.
*/
public Throwable getRootCause() {
Throwable rootCause = null;
Throwable cause = getCause();
while (cause != null && cause != rootCause) {
rootCause = cause;
cause = cause.getCause();
}
return rootCause;
}
/**
* Retrieve the most specific cause of this exception, that is,
* either the innermost cause (root cause) or this exception itself.
* <p>Differs from {@link #getRootCause()} in that it falls back
* to the present exception if there is no root cause.
*
* @return the most specific cause (never <code>null</code>)
*/
public Throwable getMostSpecificCause() {
Throwable rootCause = getRootCause();
return (rootCause != null ? rootCause : this);
}
/**
* Check whether this exception contains an exception of the given type:
* either it is of the given class itself or it contains a nested cause
* of the given type.
*
* @param exType the exception type to look for
* @return whether there is a nested exception of the specified type
*/
public boolean contains(Class exType) {
if (exType == null) {
return false;
}
if (exType.isInstance(this)) {
return true;
}
Throwable cause = getCause();
if (cause == this) {
return false;
}
if (cause instanceof ElasticSearchException) {
return ((ElasticSearchException) cause).contains(exType);
} else {
while (cause != null) {
if (exType.isInstance(cause)) {
return true;
}
if (cause.getCause() == cause) {
break;
}
cause = cause.getCause();
}
return false;
}
}
}