Module eclipselink

Class 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 Detail

      • 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 of SDOHelperContext. If not, an exception will be thrown.
        Parameters:
        helperContext -
        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