blob: 835b9e6f62d4b2272167976e96963f474e419ff8 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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.apache.uima;
import java.util.Locale;
/**
* This is the superclass for all checked exceptions in UIMA.
*
* It adds use of a "standard" bundle resource, if the subclasses don't define this.
*
* <p>
* <code>UIMAException</code> extends {@link InternationalizedException} for internationalization
* support. Since UIMA Exceptions are internationalized, the thrower does not supply a hardcoded
* message. Instead, the thrower specifies a key that identifies the message. That key is then
* looked up in a locale-specific {@link java.util.ResourceBundle ResourceBundle} to find the actual
* message associated with this exception.
* <p>
* The thrower may specify the name of the <code>ResourceBundle</code> in which to find the
* exception message. Any name may be used. If the name is omitted, the resource bundle identified
* by {@link #resource_file} will be used. This contains the standard UIMA exception
* messages.
*
*
*/
public class UIMARuntimeException extends RuntimeException implements I18nExceptionI {
private static final long serialVersionUID = 1L;
/**
* The name of the {@link java.util.ResourceBundle ResourceBundle} containing the standard UIMA
* Exception messages.
*/
public static final String resource_file = "org.apache.uima.UIMAException_Messages";
/**
* Message key for a standard UIMA exception message: CasManager.releaseCas(CAS) was called with a
* CAS that does not belong to this CasManager.
*/
public static final String CAS_RELEASED_TO_WRONG_CAS_MANAGER = "cas_released_to_wrong_cas_manager";
/**
* Message key for a standard UIMA exception message: "The Ecore model for the UIMA built-in types
* (uima.ecore) was not found in the classpath."
*/
public static final String UIMA_ECORE_NOT_FOUND = "uima_ecore_not_found";
/**
* Message key for a standard UIMA exception message: "The Ecore model contained an unresolved
* proxy {0}."
*/
public static final String ECORE_UNRESOLVED_PROXY = "ecore_unresolved_proxy";
/**
* Message key for a standard UIMA exception message: "AnalysisComponent "{0}" requested more
* CASes ({1}) than defined in its getCasInstancesRequired() method ({2}). It is possible that the
* AnalysisComponent is not properly releasing CASes when it encounters an error."
*/
public static final String REQUESTED_TOO_MANY_CAS_INSTANCES = "requested_too_many_cas_instances";
/**
* Message key for a standard UIMA exception message: "The method CasManager.defineCasPool() was
* called twice by the same Analysis Engine ({0)}."
*/
public static final String DEFINE_CAS_POOL_CALLED_TWICE = "define_cas_pool_called_twice";
/**
* Message key for a standard UIMA exception message: "Unsupported CAS interface {0}."
*/
public static final String UNSUPPORTED_CAS_INTERFACE = "unsupported_cas_interface";
/**
* Message key for a standard UIMA exception message: "Incompatible taf jni library {0}."
*/
public static final String INCOMPATIBLE_TAF_JNI_LIBRARY = "incompatible_taf_jni_library";
/**
* Message key for a standard UIMA exception message: "Attempted to copy a FeatureStructure of
* type "{0}", which is not defined in the type system of the destination CAS."
*/
public static final String TYPE_NOT_FOUND_DURING_CAS_COPY = "type_not_found_during_cas_copy";
/**
* Message key for a standard UIMA exception message: "Attempted to copy a Feature "{0}", which is
* not defined in the type system of the destination CAS."
*/
public static final String FEATURE_NOT_FOUND_DURING_CAS_COPY = "feature_not_found_during_cas_copy";
// /**
// * Message key for a standard UIMA exception message:
// * "CAS Copying of the same view to the same CAS with the same view name is not allowed."
// */
// public static final String ILLEGAL_CAS_COPY_TO_SAME_CAS_SAME_VIEW = "illegal_copy_same_cas_same_view";
/**
* Message key for a standard UIMA exception message:
* CAS Copying of Feature "{0}": range names must be the same: source range name was "{1}", target range name was "{2}".
*/
public static final String COPY_CAS_RANGE_TYPE_NAMES_NOT_EQUAL = "copy_cas_range_type_names_not_equal";
/**
* Message key for a standard UIMA exception message:
* Saved UIMA context is null; probable cause: Annotator initialize(context) method failed to call super.initialize(context).
*/
public static final String UIMA_CONTEXT_NULL = "uima_context_null";
/**
* Message key for a standard UIMA exception message:
* Saved result specification is null; probable cause: Annotator overrode setResultSpecification(spec) but failed to call super.setResultSpecification(spec).
*/
public static final String RESULT_SPEC_NULL = "result_spec_null";
/**
* Message key for a standard UIMA exception message:
* In CasCopier, the {0} view is doesn't belong to the original {0} CAS specified when creating the CasCopier instance
*/
public static final String VIEW_NOT_PART_OF_CAS = "view_not_part_of_cas";
/**
* Message key for a standard UIMA exception message:
* Unsupported invocation of CasCopier copyCasView, specifying a source or destination as a base CAS.
*/
public static final String UNSUPPORTED_CAS_COPY_TO_OR_FROM_BASE_CAS = "unsupported_cas_copy_view_base_cas";
/**
* Message key for a standard UIMA exception message:
* It is not permitted to use CasCopier to copy a Cas to itself, even in another view.
*/
public static final String ILLEGAL_CAS_COPY_TO_SAME_CAS = "illegal_cas_copy_to_same_cas";
/**
* Message key for a standard UIMA exception message: "Illegal adding of additional MetaData after
* CASes have been defined. Likely cause is the reuse of a Resource Manager object for a different
* pipeline, after it has already been initialized."
*/
public static final String ILLEGAL_ADDING_OF_NEW_META_INFO_AFTER_CAS_DEFINED = "illegal_adding_of_new_meta_info";
/**
* Message key for a standard UIMA exception message:
* Illegal update of indexed Feature Structure feature used as an key in one or more indexes
*/
public static final String ILLEGAL_FS_FEAT_UPDATE = "illegal_update_indexed_fs";
/** This method depends on having a CAS Heap design, and is not support in UIMA Version 3 and later **/
public static final String NOT_SUPPORTED_NO_HEAP_IN_UIMA_V3 = "NOT_SUPPORTED_NO_HEAP_IN_UIMA_V3";
/** Internal Error - should never happen. Nested exception if present: {0}*/
public static final String INTERNAL_ERROR = "INTERNAL_ERROR";
/**
* the message bundle to use for this exception
*/
private String mMessageBundle = resource_file;
/**
* An identifier that maps to the message for this exception.
*/
private String mMessageKey;
/**
* The arguments to this exception's message, if any. This allows an
* <code>InternationalizedRuntimeException</code> to have a compound message, made up of
* multiple parts that are concatenated in a language-neutral way.
*/
private Object[] mArguments;
/**
* The exception that caused this exception to occur.
*/
private Throwable mCause;
/**
* Categories of constructor
* 0 args
* 1 arg: throwable cause
* 1 - n args: First String message key, rest Object arguments
* 2 - n args: First is throwable, 2nd is String message key, rest Object arguments
*
*/
/**
* Creates a new exception with a null message.
*/
public UIMARuntimeException() {
super();
}
/**
* Creates a new exception with the specified cause and a null message.
*
* @param aCause
* the original exception that caused this exception to be thrown, if any
*/
public UIMARuntimeException(Throwable aCause) {
super(aCause);
mCause = aCause;
if (mMessageKey == null && (aCause instanceof I18nExceptionI)) {
I18nExceptionI cause = (I18nExceptionI)aCause;
mMessageKey = cause.getMessageKey();
mArguments = cause.getArguments();
}
}
/**
* Creates a new exception with a message from the {@link #resource_file}.
*
* @param aMessageKey
* an identifier that maps to the message for this exception. The message may contain
* placeholders for arguments as defined by the
* {@link java.text.MessageFormat MessageFormat} class.
* @param aArguments
* The arguments to the message. <code>null</code> may be used if the message has no
* arguments.
*/
public UIMARuntimeException(String aMessageKey, Object ... aArguments) {
this((Throwable)null, aMessageKey, aArguments);
}
public UIMARuntimeException(String messageBundle, String messageKey, Object[] arguments) {
this(messageKey, arguments);
mMessageBundle = messageBundle;
}
/**
* Creates a new exception with the specified message and cause.
*
* @param aMessageKey
* an identifier that maps to the message for this exception. The message may contain
* placeholders for arguments as defined by the
* {@link java.text.MessageFormat MessageFormat} class.
* @param aArguments
* The arguments to the message. <code>null</code> may be used if the message has no
* arguments.
* @param aCause
* the original exception that caused this exception to be thrown, if any
*/
public UIMARuntimeException(Throwable aCause, String aMessageKey, Object ... aArguments) {
super();
mCause = aCause;
mMessageKey = aMessageKey;
mArguments = aArguments;
// if null message and mCause is UIMAException (e.g. a checked exception that is wrapped), "promote" message
if (mMessageKey == null) {
if (mCause instanceof I18nExceptionI) {
I18nExceptionI cause = (I18nExceptionI)mCause;
mMessageKey = cause.getMessageKey();
mArguments = cause.getArguments();
}
}
}
/**
* Gets the base name of the resource bundle in which the message for this exception is located.
*
* @return the resource bundle base name. May return <code>null</code> if this exception has no
* message.
*/
@Override
public String getResourceBundleName() {
return mMessageBundle;
}
/**
* Gets the identifier for this exception's message. This identifier can be looked up in this
* exception's {@link java.util.ResourceBundle ResourceBundle} to get the locale-specific message
* for this exception.
*
* @return the resource identifier for this exception's message. May return <code>null</code> if
* this exception has no message.
*/
@Override
public String getMessageKey() {
return mMessageKey;
}
/**
* Gets the arguments to this exception's message. Arguments allow a
* <code>InternationalizedRuntimeException</code> to have a compound message, made up of
* multiple parts that are concatenated in a language-neutral way.
*
* @return the arguments to this exception's message.
*/
@Override
public Object[] getArguments() {
if (mArguments == null)
return new Object[0];
return mArguments.clone();
}
/**
* Gets the cause of this Exception.
*
* @return the Throwable that caused this Exception to occur, if any. Returns <code>null</code>
* if there is no such cause.
*/
@Override
public Throwable getCause() {
return mCause;
}
@Override
public synchronized Throwable initCause(Throwable cause) {
mCause = cause;
return this;
}
/**
* @return The message of the exception. Useful for including the text in
* another exception.
*/
public String getMessage() {
return getLocalizedMessage(Locale.ENGLISH);
}
/**
* Gets the localized detail message for this exception. This uses the default
* Locale for this JVM. A Locale may be specified using
* {@link #getLocalizedMessage(Locale)}.
*
* @return this exception's detail message, localized for the default Locale.
*/
public String getLocalizedMessage() {
return getLocalizedMessage(Locale.getDefault());
}
}