- java.lang.Object
-
- org.eclipse.persistence.sdo.SDOHelper
-
public class SDOHelper extends Object
This class provides a mechanism to obtain the EclipseLink implementation of various SDO runtime classes based on a given SDO class/interface. This is useful for accessing extended EclipseLink features. Using this helper class will alleviate the need for consumers of EclipseLink SDO to perform casts where their code makes use of the standard SDO API. In addition, a given SDO class/interface can be unwrapped based on a user-specified class. This will allow access - in certain cases - to a given SDO implementation class' underlying class(es). For example, an XMLHelper could be unwrapped resulting in an EclipseLink SDOXMLHelper or its underlying XMLContext.
-
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static SDOChangeSummary
getChangeSummary(ChangeSummary changeSummary)
Return the EclipseLink implementation of ChangeSummary.static SDOCopyHelper
getCopyHelper(CopyHelper copyHelper)
Return the EclipseLink implementation of CopyHelper.static SDODataFactory
getDataFactory(DataFactory dataFactory)
Return the EclipseLink implementation of DataFactory.static SDODataHelper
getDataHelper(DataHelper dataHelper)
Return the EclipseLink implementation of DataHelper.static SDODataObject
getDataObject(DataObject dataObject)
Return the EclipseLink implementation of DataObject.static SDOEqualityHelper
getEqualityHelper(EqualityHelper equalityHelper)
Return the EclipseLink implementation of EqualityHelper.static SDOHelperContext
getHelperContext(HelperContext helperContext)
Return the EclipseLink implementation of HelperContext.static SDOProperty
getProperty(Property property)
Return the EclipseLink implementation of Property.static SDOSequence
getSequence(Sequence sequence)
Return the EclipseLink implementation of Sequence.static SDOType
getType(Type type)
Return the EclipseLink implementation of Type.static SDOTypeHelper
getTypeHelper(TypeHelper typeHelper)
Return the EclipseLink implementation of TypeHelper.static SDOXMLHelper
getXMLHelper(XMLHelper xmlHelper)
Return the EclipseLink implementation of XMLHelper.static SDOXSDHelper
getXSDHelper(XSDHelper xsdHelper)
Return the EclipseLink implementation of XSDHelper.static <T> T
unwrap(ChangeSummary changeSummary, Class<T> clazz)
Unwraps a given ChangeSummary resulting in an EclipseLink SDOChangeSummary.static <T> T
unwrap(DataObject dataObject, Class<T> clazz)
Unwraps a given DataObject resulting in an EclipseLink SDODataObject.static <T> T
unwrap(CopyHelper copyHelper, Class<T> clazz)
Unwraps a given CopyHelper resulting in an EclipseLink SDOCopyHelper.static <T> T
unwrap(DataFactory dataFactory, Class<T> clazz)
Unwraps a given DataFactory resulting in an EclipseLink SDODataFactory.static <T> T
unwrap(DataHelper dataHelper, Class<T> clazz)
Unwraps a given DataHelper resulting in an EclipseLink SDODataHelper.static <T> T
unwrap(EqualityHelper equalityHelper, Class<T> clazz)
Unwraps a given EqualityHelper resulting in an EclipseLink SDOEqualityHelper.static <T> T
unwrap(HelperContext helperContext, Class<T> clazz)
Unwraps a given HelperContext resulting in an EclipseLink SDOHelperContext.static <T> T
unwrap(TypeHelper typeHelper, Class<T> clazz)
Unwraps a given TypeHelper resulting in an EclipseLink SDOTypeHelper.static <T> T
unwrap(XMLHelper xmlHelper, Class<T> clazz)
Unwraps a given XMLHelper resulting in an EclipseLink SDOXMLHelper or an EclipseLink XMLContext depending on clazz.static <T> T
unwrap(XSDHelper xsdHelper, Class<T> clazz)
Unwraps a given XSDHelper resulting in an EclipseLink SDOXSDHelper.static <T> T
unwrap(Property property, Class<T> clazz)
Unwraps a given Property resulting in an EclipseLink SDOProperty.static <T> T
unwrap(Sequence sequence, Class<T> clazz)
Unwraps a given Sequence resulting in an EclipseLink SDOSequence.static <T> T
unwrap(Type type, Class<T> clazz)
Unwraps a given Type resulting in an EclipseLink SDOType.
-
-
-
Method Detail
-
getType
public static SDOType getType(Type type) throws IllegalArgumentException
Return the EclipseLink implementation of Type. The given Type is assumed to be an instance ofSDOType
. If not, an exception will be thrown.- Parameters:
type
-- Returns:
- Throws:
IllegalArgumentException
-
getProperty
public static SDOProperty getProperty(Property property) throws IllegalArgumentException
Return the EclipseLink implementation of Property. The given Property is assumed to be an instance ofSDOProperty
. If not, an exception will be thrown.- Parameters:
property
-- Returns:
- Throws:
IllegalArgumentException
-
getDataObject
public static SDODataObject getDataObject(DataObject dataObject) throws IllegalArgumentException
Return the EclipseLink implementation of DataObject. The given DataObject is assumed to be an instance ofSDODataObject
. If not, an exception will be thrown.- Parameters:
dataObject
-- Returns:
- Throws:
IllegalArgumentException
-
getChangeSummary
public static SDOChangeSummary getChangeSummary(ChangeSummary changeSummary) throws IllegalArgumentException
Return the EclipseLink implementation of ChangeSummary. The given ChangeSummary is assumed to be an instance ofSDOChangeSummary
. If not, an exception will be thrown.- Parameters:
changeSummary
-- Returns:
- Throws:
IllegalArgumentException
-
getSequence
public static SDOSequence getSequence(Sequence sequence) throws IllegalArgumentException
Return the EclipseLink implementation of Sequence. The given Sequence is assumed to be an instance ofSDOSequence
. If not, an exception will be thrown.- Parameters:
sequence
-- Returns:
- Throws:
IllegalArgumentException
-
getHelperContext
public static SDOHelperContext getHelperContext(HelperContext helperContext) throws IllegalArgumentException
Return the EclipseLink implementation of HelperContext. If the given HelperContext is an instance of the DefaultContext, an SDOHelperContext will be obtained via SDOHelperContext.getHelperContext(). Otherwise, the given HelperContext is assumed to be an instance ofSDOHelperContext
. If not, an exception will be thrown.- Parameters:
helperContext
-- Returns:
- Throws:
IllegalArgumentException
-
getCopyHelper
public static SDOCopyHelper getCopyHelper(CopyHelper copyHelper) throws IllegalArgumentException
Return the EclipseLink implementation of CopyHelper. The given CopyHelper is assumed to be an instance ofSDOCopyHelper
. If not, an exception will be thrown.- Parameters:
copyHelper
-- Returns:
- Throws:
IllegalArgumentException
-
getDataFactory
public static SDODataFactory getDataFactory(DataFactory dataFactory) throws IllegalArgumentException
Return the EclipseLink implementation of DataFactory. The given DataFactory is assumed to be an instance ofSDODataFactory
. If not, an exception will be thrown.- Parameters:
dataFactory
-- Returns:
- Throws:
IllegalArgumentException
-
getDataHelper
public static SDODataHelper getDataHelper(DataHelper dataHelper) throws IllegalArgumentException
Return the EclipseLink implementation of DataHelper. The given DataHelper is assumed to be an instance ofSDODataHelper
. If not, an exception will be thrown.- Parameters:
dataHelper
-- Returns:
- Throws:
IllegalArgumentException
-
getEqualityHelper
public static SDOEqualityHelper getEqualityHelper(EqualityHelper equalityHelper) throws IllegalArgumentException
Return the EclipseLink implementation of EqualityHelper. The given EqualityHelper is assumed to be an instance ofSDOEqualityHelper
. If not, an exception will be thrown.- Parameters:
equalityHelper
-- Returns:
- Throws:
IllegalArgumentException
-
getTypeHelper
public static SDOTypeHelper getTypeHelper(TypeHelper typeHelper) throws IllegalArgumentException
Return the EclipseLink implementation of TypeHelper. The given TypeHelper is assumed to be an instance ofSDOTypeHelper
. If not, an exception will be thrown.- Parameters:
typeHelper
-- Returns:
- Throws:
IllegalArgumentException
-
getXMLHelper
public static SDOXMLHelper getXMLHelper(XMLHelper xmlHelper) throws IllegalArgumentException
Return the EclipseLink implementation of XMLHelper. The given XMLHelper is assumed to be an instance ofSDOXMLHelper
. If not, an exception will be thrown.- Parameters:
xmlHelper
-- Returns:
- Throws:
IllegalArgumentException
-
getXSDHelper
public static SDOXSDHelper getXSDHelper(XSDHelper xsdHelper) throws IllegalArgumentException
Return the EclipseLink implementation of XSDHelper. The given XSDHelper is assumed to be an instance ofSDOXSDHelper
. If not, an exception will be thrown.- Parameters:
xsdHelper
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(Type type, Class<T> clazz) throws IllegalArgumentException
Unwraps a given Type resulting in an EclipseLink SDOType. Assumes that the given Type is an instance of EclipseLink SDOType, and clazz is one of: org.eclipse.persistence.sdo.SDOType, org.eclipse.persistence.sdo.type.SDOTypeType, org.eclipse.persistence.sdo.type.SDOPropertyType, org.eclipse.persistence.sdo.type.SDOChangeSummaryType, org.eclipse.persistence.sdo.type.SDODataObjectType, org.eclipse.persistence.sdo.type.SDODataType, org.eclipse.persistence.sdo.type.SDOOpenSequencedType, org.eclipse.persistence.sdo.type.SDOObjectType, org.eclipse.persistence.sdo.type.SDOWrapperType, org.eclipse.persistence.sdo.type.SDOXMLHelperLoadOptionsType- Type Parameters:
T
-- Parameters:
type
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(Property property, Class<T> clazz) throws IllegalArgumentException
Unwraps a given Property resulting in an EclipseLink SDOProperty. Assumes that the given Property is an instance of EclipseLink SDOProperty, and clazz is org.eclipse.persistence.sdo.SDOProperty.- Type Parameters:
T
-- Parameters:
property
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(DataObject dataObject, Class<T> clazz) throws IllegalArgumentException
Unwraps a given DataObject resulting in an EclipseLink SDODataObject. Assumes that the given DataObject is an instance of EclipseLink SDODataObject, and clazz is org.eclipse.persistence.sdo.SDODataObject.- Type Parameters:
T
-- Parameters:
dataObject
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(ChangeSummary changeSummary, Class<T> clazz) throws IllegalArgumentException
Unwraps a given ChangeSummary resulting in an EclipseLink SDOChangeSummary. Assumes that the given ChangeSummary is an instance of EclipseLink SDOChangeSummary, and clazz is org.eclipse.persistence.sdo.SDOChangeSummary.- Type Parameters:
T
-- Parameters:
changeSummary
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(Sequence sequence, Class<T> clazz) throws IllegalArgumentException
Unwraps a given Sequence resulting in an EclipseLink SDOSequence. Assumes that the given Sequence is an instance of EclipseLink SDOSequence, and clazz is org.eclipse.persistence.sdo.SDOSequence.- Type Parameters:
T
-- Parameters:
sequence
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(HelperContext helperContext, Class<T> clazz) throws IllegalArgumentException
Unwraps a given HelperContext resulting in an EclipseLink SDOHelperContext. Assumes that the given HelperContext is an instance of EclipseLink SDOHelperContext, and clazz is org.eclipse.persistence.sdo.helper.SDOHelperContext.- Type Parameters:
T
-- Parameters:
helperContext
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(CopyHelper copyHelper, Class<T> clazz) throws IllegalArgumentException
Unwraps a given CopyHelper resulting in an EclipseLink SDOCopyHelper. Assumes that the given CopyHelper is an instance of EclipseLink SDOCopyHelper, and clazz is org.eclipse.persistence.sdo.helper.SDOCopyHelper.- Type Parameters:
T
-- Parameters:
copyHelper
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(DataFactory dataFactory, Class<T> clazz) throws IllegalArgumentException
Unwraps a given DataFactory resulting in an EclipseLink SDODataFactory. Assumes that the given DataFactory is an instance of EclipseLink SDODataFactory, and clazz is org.eclipse.persistence.sdo.helper.SDODataFactory.- Type Parameters:
T
-- Parameters:
dataFactory
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(DataHelper dataHelper, Class<T> clazz) throws IllegalArgumentException
Unwraps a given DataHelper resulting in an EclipseLink SDODataHelper. Assumes that the given DataHelper is an instance of EclipseLink SDODataHelper, and clazz is org.eclipse.persistence.sdo.helper.SDODataHelper.- Type Parameters:
T
-- Parameters:
dataHelper
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(EqualityHelper equalityHelper, Class<T> clazz) throws IllegalArgumentException
Unwraps a given EqualityHelper resulting in an EclipseLink SDOEqualityHelper. Assumes that the given EqualityHelper is an instance of EclipseLink SDOEqualityHelper, and clazz is org.eclipse.persistence.sdo.helper.SDOEqualityHelper.- Type Parameters:
T
-- Parameters:
equalityHelper
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(TypeHelper typeHelper, Class<T> clazz) throws IllegalArgumentException
Unwraps a given TypeHelper resulting in an EclipseLink SDOTypeHelper. Assumes that the given TypeHelper is an instance of EclipseLink SDOTypeHelper, and clazz is org.eclipse.persistence.sdo.helper.SDOTypeHelper.- Type Parameters:
T
-- Parameters:
typeHelper
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(XMLHelper xmlHelper, Class<T> clazz) throws IllegalArgumentException
Unwraps a given XMLHelper resulting in an EclipseLink SDOXMLHelper or an EclipseLink XMLContext depending on clazz. Assumes that the given XMLHelper is an instance of EclipseLink SDOXMLHelper, and clazz is one of org.eclipse.persistence.sdo.helper.SDOXMLHelper, or org.eclipse.persistence.oxm.XMLContext. If not, an exception will be thrown.- Type Parameters:
T
-- Parameters:
xmlHelper
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
unwrap
public static <T> T unwrap(XSDHelper xsdHelper, Class<T> clazz) throws IllegalArgumentException
Unwraps a given XSDHelper resulting in an EclipseLink SDOXSDHelper. Assumes that the given XSDHelper is an instance of EclipseLink SDOXSDHelper, and clazz is org.eclipse.persistence.sdo.helper.SDOXSDHelper.- Type Parameters:
T
-- Parameters:
xsdHelper
-clazz
-- Returns:
- Throws:
IllegalArgumentException
-
-