Class ConfigurablePofContext
- java.lang.Object
- 
- com.tangosol.io.pof.ConfigurablePofContext
 
- 
- All Implemented Interfaces:
- ClassLoaderAware,- PofContext,- Serializer,- XmlConfigurable
 - Direct Known Subclasses:
- SafeConfigurablePofContext
 
 @Named("pof") public class ConfigurablePofContext extends Object implements PofContext, ClassLoaderAware, XmlConfigurableThis class implements thePofContextinterface using information provided in a configuration file (or in a passed XML configuration) as well as classes annotated withPortableType.For each user type supported by this POF context, it must be provided with: - A valid user type ID that is unique within this POF context;
- A Java class name that identifies a Java class or interface that all values of the user type are type-assignable to (and that no values of other user types are type-assignable to); in other words, all values of the user type (and no values of other user types) are instances of the specified class, instances of a sub-class of the specified class, or (if it is an interface) instances of a class that implements the specified interface;
- A Java class name that identifies a non-abstract implementation of the PofSerializer interface.
 The format of the configuration XML is as follows: 
 For each user type, a user-type element must exist inside the user-type-list element. The user-type-list element contains up to three elements, in the following order:<pof-config> <user-type-list> .. <user-type> <type-id>53</type-id> <class-name>com.mycompany.data.Trade</class-name> <serializer> <class-name>com.tangosol.io.pof.PortableObjectSerializer</class-name> <init-params> <init-param> <param-type>int</param-type> <param-value>{type-id}</param-value> </init-param> </init-params> </serializer> </user-type> <user-type> <type-id>54</type-id> <class-name>com.mycompany.data.Position</class-name> </user-type> .. <include>file:/my-pof-config.xml</include> .. </user-type-list> <allow-interfaces>false</allow-interfaces> <allow-subclasses>false</allow-subclasses> </pof-config>- The user-type element should contain a type-id element whose value specifies the unique integer type ID; if none of the user-type elements contains a type-id element, then the type IDs for the user types will be based on the order in which they appear in the configuration, with the first user type being assigned the type ID 0, the second user type being assigned the type ID 1, and so on. (It is strongly recommended that user types IDs always be specified, in order to support schema versioning and evolution.)
- The class-name element is required, and specifies the fully qualified name of the Java class or interface that all values of the user type are type-assignable to.
- The serializer element is used to specify an implementation of
     PofSerializer to use to serialize and deserialize user type values to
     and from a POF stream. Within the serializer element, the
     class-name element is required, and zero or more constructor
     parameters can be defined within an init-params block. If no
     serializer is specified, either implement the PortableObject
     interface or have a Portableannotation. If the former, aPortableObjectSerializerwill be used. If the later, aPofAnnotationSerializerwill be used.
 The optional include element allows user-type elements defined in another configuration XML to be added to the user type list. The value of this element is a locator string (either a valid path or URL) that specifies the location of the target PofContext configuration file. The user-type elements of the target file are imported verbatum; therefore, if the included elements contain explicit type identifiers, each identifier must be unique with respect to the the user type identifiers (either explicit or generated) defined within the including file. If the included user types do not contain explicit type identifiers, then the type identifiers will be based on the order in which the user types appear in the composite configuration file. Multiple include elements may be used within a single user-type-list element. The ConfigurablePofContext is truly ClassLoader-aware. It is conceivable that the ConfigurablePofContext is loaded by the system ClassLoader (or some other relatively global ClassLoader), while the objects deserialized by the PofContext are loaded by an application-specific ClassLoader, such as is typical within an application server. The ConfigurablePofContext is designed to load the configuration, the POF-able object classes and the PofSerializer classes from within a specified ClassLoader context, and to pass the ClassLoader information on to the PofSerializer instances, just in case they are not loaded from within the application's ClassLoader context. In other words, the ConfigurablePofContext, its configuration, the PofSerializer classes and the POF-able classes can all be loaded by the same ClassLoader, or they can all be loaded by different ClassLoaders, so long as the configuration, the POF-able classes and the PofSerializer classes can be loaded by either the specified ClassLoader or by the ClassLoader that loaded the ConfigurablePofContext itself. In order to be used by the ConfigurablePofContext, a PofSerializer implementation must provide a public constructor that accepts the parameters detailed by the init-params element. The parameter values, as specified by the param-value element, can specify one of the following substitutable values: - {type-id} - replaced with the Type ID of the User Type;
- {class-name} - replaced with the name of the class for the User Type;
- {class} - replaced with the Class for the User Type;
- {class-loader} - replaced with the ConfigurablePofContext's ContextClassLoader.
 - (int nTypeId, Class clz, ClassLoader loader)
- (int nTypeId, Class clz)
- (int nTypeId)
- ()
 Once constructed, if the PofSerializer implements the XmlConfigurable interface, the setConfigmethod is invoked, and it is passed the parameter XML information, transposed as described bytransformInitParams, and as described in the coherence-pof-config.xsd file.Finally, if the PofSerializer implements the ClassLoaderAware interface and a ClassLoader has been specified, then the setContextClassLoadermethod is invoked with the reference to the specified ClassLoader.Conceptually, the identity of a ConfigurablePofContext is a combination of a configuration locator and a ClassLoader. The ClassLoader is used to resolve and load the configuration details whose location is specified by the configuration locator, and to load all of the classes specified by the configuration. To achieve acceptable performance, and to limit the redundant use of resources, the ConfigurablePofContext maintains a WeakHashMap keyed by ClassLoader, whose corresponding values are each a SafeHashMap keyed by configuration locator, whose corresponding values contain the data necessary to efficiently perform the operations prescribed by the PofContext interface. Note: The configuration for the default constructorcan be specified using thetangosol.pof.configsystem property.- Since:
- Coherence 3.2
- Author:
- jh/cp 2006.07.24
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classConfigurablePofContext.PofConfigThe information related to the configuration of a particular PofContext for a specific URI and ClassLoader.
 - 
Field SummaryFields Modifier and Type Field Description protected static StringDEFAULT_INDEX_FILE_NAMEDefault Jandex index file.static StringDEFAULT_RESOURCEThe name of the application resource that contains the default set of wire-format-to-object bindings.static StringPROPERTY_CONFIGThe name of the system property ("tangosol.pof.config") that can be used to override the location of the default POF configuration file.protected static ClassROOT_LAMBDA_CLASSMarker serving as the implicit root class for all lambdas.
 - 
Constructor SummaryConstructors Constructor Description ConfigurablePofContext()Default constructor.ConfigurablePofContext(ConfigurablePofContext that)Copy constructor for a ConfigurablePofContext.ConfigurablePofContext(XmlElement xml)Create a ConfigurablePofContext that will use the passed configuration information.ConfigurablePofContext(String sLocator)Create a ConfigurablePofContext that will load configuration information from the specified locator.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected static voidappendDefaultSerializerToUserTypes(XmlElement xmlConfig)Process <default-serializer> element from the specified xml configuration and append information about the serializer to each <user-type> element within <user-type-list> unless user type already has a serializer specified.protected voidcheckNotInitialized()Verify that the ConfigurablePofContext has not already been initialized.protected ConfigurablePofContext.PofConfigcreatePofConfig()Create a PofConfig object based on a configuration that was either provided as XML, or can be loaded from the specified (or default) URI using the provided ClassLoader.Objectdeserialize(ReadBuffer.BufferInput in)Deserialize an object from a ReadBuffer by reading its state using the specified BufferInput object.protected voidensureInitialized()Fully initialize the ConfigurablePofContext if it has not already been initialized.ClassgetClass(int nTypeId)Determine the class associated with the given user type identifier.StringgetClassName(int nTypeId)Determine the name of the class associated with the given user type identifier.XmlElementgetConfig()Determine the current configuration of the object.protected StringgetConfigLocation()Obtain the location of the configuration that the ConfigurablePofContext used to configure itself.ClassLoadergetContextClassLoader()Retrieve the context ClassLoader for this object.StringgetIndexFileName()Return the Jandex index file name to use to discover portable types.protected intgetInheritedUserTypeIdentifier(Class clz)Helper method for determining the user type identifier associated with a given class that does not have a direct configured association.StringgetName()Return the name of this serializer.protected ConfigurablePofContext.PofConfiggetPofConfig()Obtain the PofConfig that represents the initialized state of the ConfigurablePofContext.PofSerializergetPofSerializer(int nTypeId)Return a PofSerializer that can be used to serialize and deserialize an object of the specified user type to and from a POF stream.intgetUserTypeIdentifier(Class clz)Determine the user type identifier associated with the given class.intgetUserTypeIdentifier(Object o)Determine the user type identifier associated with the given object.intgetUserTypeIdentifier(String sClass)Determine the user type identifier associated with the given class name.protected intgetUserTypeIdentifierInternal(Class clz)Determine the user type identifier associated with the given class.protected intgetUserTypeIdentifierInternal(String sClass)Determine the user type identifier associated with the given class name.protected voidinitialize()Bind the ConfigurablePofContext to a ClassLoader, resolving all class names, etc.protected PofSerializerinstantiateSerializer(XmlElement xmlSer, int nTypeId, Class clz)Create aPofSerializerfrom the provided XML serializer element.protected PofSerializer<?>instantiateSerializer(Class<? extends PofSerializer> clzSer, Integer nTypeId, Class<?> clz)Instantiate specifiedPofSerializer.protected booleanisInitialized()Determine if the ConfigurablePofContext has completed its initialization.protected booleanisInterfaceAllowed()Determine if the ConfigurablePofContext supports the configuration of user types by specifying an interface (instead of a class) for the Java type.protected booleanisLambdaAllowed()Determine if implicit root lambda class processing is allowed.booleanisPreferJavaTime()ReturntrueifPofReader.readObject(int)method should return the appropriate Java 8 date/time type, orfalseif a legacy date/time types should be returned in order to preserve backwards compatibility.booleanisReferenceEnabled()Determine if Identity/Reference type support is enabled for this ConfigurablePofContext.protected booleanisSubclassAllowed()Determine if the ConfigurablePofContext supports the serialization of an object that is an instance of a sub-class of a configured type, but not actually an instance of a class of a configured type.booleanisUserType(Class clz)Determine if the given class is a user type known to this PofContext.booleanisUserType(Object o)Determine if the given object is of a user type known to this PofContext.booleanisUserType(String sClass)Determine if the class with the given name is a user type known to this PofContext.protected ClassloadClass(String sClass)Find the specified class, return a Java Class object for it.static voidmergeIncludes(String sURI, XmlElement xmlConfig, ClassLoader loader)Merge all included POF configuration files into the given xml configuration.protected voidreport(String sURI, int nTypeId, String sClass, Throwable e, String sText)Assemble and throw an informative exception based on the passed details.voidserialize(WriteBuffer.BufferOutput out, Object o)Serialize an object to a WriteBuffer by writing its state using the specified BufferOutput object.voidsetConfig(XmlElement xml)Specify the configuration for the object.voidsetContextClassLoader(ClassLoader loader)Specify the context ClassLoader for this object.voidsetIndexFileName(String sIndexFile)Set the Jandex index file name to use to discover portable types.voidsetPreferJavaTime(boolean fPreferJavaTime)Set the flag specifying if Java 8 date/time types (java.time.*) should be preferred over legacy types.voidsetReferenceEnabled(boolean fReferenceEnabled)Set the referenceEnabled flag.StringtoString()Return a description of this ConfigurablePofContext.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface com.tangosol.io.Serializerdeserialize
 
- 
 
- 
- 
- 
Field Detail- 
PROPERTY_CONFIGpublic static final String PROPERTY_CONFIG The name of the system property ("tangosol.pof.config") that can be used to override the location of the default POF configuration file.The value of this property must be the name of a resource that contains an XML document with the structure defined in /coherence-pof-config.xsd (deployed in coherence.jar). The default value for the "coherence.pof.config" system property is "coherence-pof-config.xml". - See Also:
- Constant Field Values
 
 - 
DEFAULT_RESOURCEpublic static final String DEFAULT_RESOURCE The name of the application resource that contains the default set of wire-format-to-object bindings.The default value for the resource name is "pof-config.xml". The default can be overriden by specifying a value for the tangosol.pof.configsystem property.
 - 
ROOT_LAMBDA_CLASSprotected static final Class ROOT_LAMBDA_CLASS Marker serving as the implicit root class for all lambdas.
 - 
DEFAULT_INDEX_FILE_NAMEprotected static final String DEFAULT_INDEX_FILE_NAME Default Jandex index file.- See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
ConfigurablePofContextpublic ConfigurablePofContext() Default constructor.Create a default ConfigurablePofContext that will load configuration information from the locator specified in DEFAULT_RESOURCE.
 - 
ConfigurablePofContextpublic ConfigurablePofContext(String sLocator) Create a ConfigurablePofContext that will load configuration information from the specified locator.- Parameters:
- sLocator- the locator that specifies the location of the PofContext configuration file; the locator is either a valid path or a URL
 
 - 
ConfigurablePofContextpublic ConfigurablePofContext(XmlElement xml) Create a ConfigurablePofContext that will use the passed configuration information.- Parameters:
- xml- an XmlElement containing information in the format of a configuration file used by ConfigurablePofContext
 
 - 
ConfigurablePofContextpublic ConfigurablePofContext(ConfigurablePofContext that) Copy constructor for a ConfigurablePofContext.- Parameters:
- that- the ConfigurablePofContext to (shallow) copy from
 
 
- 
 - 
Method Detail- 
getConfigpublic XmlElement getConfig() Determine the current configuration of the object.- Specified by:
- getConfigin interface- XmlConfigurable
- Returns:
- the XML configuration or null
 
 - 
setConfigpublic void setConfig(XmlElement xml) Specify the configuration for the object.Note that the configuration cannot be set after the ConfigurablePofContext is fully initialized. - Specified by:
- setConfigin interface- XmlConfigurable
- Parameters:
- xml- the XML configuration for the object
- Throws:
- IllegalStateException- if the ConfigurablePofContext is already fully initialized
 
 - 
getContextClassLoaderpublic ClassLoader getContextClassLoader() Retrieve the context ClassLoader for this object. The context ClassLoader is provided by the creator of the object for use by the object when loading classes and resources.- Specified by:
- getContextClassLoaderin interface- ClassLoaderAware
- Returns:
- the context ClassLoader for this object
- See Also:
- Thread.getContextClassLoader()
 
 - 
setContextClassLoaderpublic void setContextClassLoader(ClassLoader loader) Specify the context ClassLoader for this object. The context ClassLoader can be set when the object is created, and allows the creator to provide the appropriate class loader to be used by the object when when loading classes and resources.Note that the ConfigurablePofContext will fully initialize when it is provided a ClassLoader. - Specified by:
- setContextClassLoaderin interface- ClassLoaderAware
- Parameters:
- loader- the context ClassLoader for this object
- Throws:
- IllegalStateException- if the ConfigurablePofContext is already fully initialized
 
 - 
serializepublic void serialize(WriteBuffer.BufferOutput out, Object o) throws IOException Serialize an object to a WriteBuffer by writing its state using the specified BufferOutput object.Note: Starting with Coherence 12.2.1 classes that need to designate an alternative object to be used by the Serializer when writing the object to the buffer should implement the SerializationSupport.writeReplace()method.- Specified by:
- serializein interface- Serializer
- Parameters:
- out- the BufferOutput with which to write the object's state
- o- the object to serialize
- Throws:
- IOException- if an I/O error occurs
 
 - 
deserializepublic Object deserialize(ReadBuffer.BufferInput in) throws IOException Deserialize an object from a ReadBuffer by reading its state using the specified BufferInput object.Note: Starting with Coherence 12.2.1 classes that need to designate an alternative object to be returned by the Serializer after an object is deserialized from the buffer should implement the SerializationSupport.readResolve()method.- Specified by:
- deserializein interface- Serializer
- Parameters:
- in- the BufferInput with which to read the object's state
- Returns:
- the deserialized user type instance
- Throws:
- IOException- if an I/O error occurs
 
 - 
getNamepublic String getName() Description copied from interface:SerializerReturn the name of this serializer.- Specified by:
- getNamein interface- Serializer
- Returns:
- the name of this serializer
 
 - 
getPofSerializerpublic PofSerializer getPofSerializer(int nTypeId) Return a PofSerializer that can be used to serialize and deserialize an object of the specified user type to and from a POF stream.- Specified by:
- getPofSerializerin interface- PofContext
- Parameters:
- nTypeId- the type identifier of the user type that can be serialized and deserialized using the returned PofSerializer; must be non-negative
- Returns:
- a PofSerializer for the specified user type
 
 - 
getUserTypeIdentifierpublic int getUserTypeIdentifier(Object o) Determine the user type identifier associated with the given object.- Specified by:
- getUserTypeIdentifierin interface- PofContext
- Parameters:
- o- an instance of a user type; must not be null
- Returns:
- the type identifier of the user type associated with the given object
 
 - 
getUserTypeIdentifierpublic int getUserTypeIdentifier(Class clz) Determine the user type identifier associated with the given class.- Specified by:
- getUserTypeIdentifierin interface- PofContext
- Parameters:
- clz- a user type class; must not be null
- Returns:
- the type identifier of the user type associated with the given class
 
 - 
getUserTypeIdentifierpublic int getUserTypeIdentifier(String sClass) Determine the user type identifier associated with the given class name.- Specified by:
- getUserTypeIdentifierin interface- PofContext
- Parameters:
- sClass- the name of a user type class; must not be null
- Returns:
- the type identifier of the user type associated with the given class name
 
 - 
getClassNamepublic String getClassName(int nTypeId) Determine the name of the class associated with the given user type identifier.- Specified by:
- getClassNamein interface- PofContext
- Parameters:
- nTypeId- the user type identifier; must be non-negative
- Returns:
- the name of the class associated with the specified user type identifier
 
 - 
getClasspublic Class getClass(int nTypeId) Determine the class associated with the given user type identifier.- Specified by:
- getClassin interface- PofContext
- Parameters:
- nTypeId- the user type identifier; must be non-negative
- Returns:
- the class associated with the specified user type identifier
 
 - 
isUserTypepublic boolean isUserType(Object o) Determine if the given object is of a user type known to this PofContext.- Specified by:
- isUserTypein interface- PofContext
- Parameters:
- o- the object to test; must not be null
- Returns:
- true iff the specified object is of a valid user type
 
 - 
isUserTypepublic boolean isUserType(Class clz) Determine if the given class is a user type known to this PofContext.- Specified by:
- isUserTypein interface- PofContext
- Parameters:
- clz- the class to test; must not be null
- Returns:
- true iff the specified class is a valid user type
 
 - 
isUserTypepublic boolean isUserType(String sClass) Determine if the class with the given name is a user type known to this PofContext.- Specified by:
- isUserTypein interface- PofContext
- Parameters:
- sClass- the name of the class to test; must not be null
- Returns:
- true iff the class with the specified name is a valid user type
 
 - 
isPreferJavaTimepublic boolean isPreferJavaTime() ReturntrueifPofReader.readObject(int)method should return the appropriate Java 8 date/time type, orfalseif a legacy date/time types should be returned in order to preserve backwards compatibility.- Specified by:
- isPreferJavaTimein interface- PofContext
- Returns:
- trueif Java 8 date/time types should be preferred over legacy types
 
 - 
getUserTypeIdentifierInternalprotected int getUserTypeIdentifierInternal(Class clz) Determine the user type identifier associated with the given class.- Parameters:
- clz- a user type class; must not be null
- Returns:
- the type identifier of the user type associated with the given class or -1 if the user type is unknown to this PofContext
 
 - 
getInheritedUserTypeIdentifierprotected int getInheritedUserTypeIdentifier(Class clz) Helper method for determining the user type identifier associated with a given class that does not have a direct configured association.- Parameters:
- clz- a user type class; must not be null
- Returns:
- the type identifier of the user type associated with the given class or -1 if the user type and its superclass(es) and implemented interface(s) are unknown to this PofContext
 
 - 
getUserTypeIdentifierInternalprotected int getUserTypeIdentifierInternal(String sClass) Determine the user type identifier associated with the given class name.- Parameters:
- sClass- the name of a user type class; must not be null
- Returns:
- the type identifier of the user type associated with the given class name or -1 if the user type is unknown to this PofContext
 
 - 
isInitializedprotected boolean isInitialized() Determine if the ConfigurablePofContext has completed its initialization.- Returns:
- true iff the initialization is complete
 
 - 
getConfigLocationprotected String getConfigLocation() Obtain the location of the configuration that the ConfigurablePofContext used to configure itself.- Returns:
- the location information for the configuration for the ConfigurablePofContext, or null if not yet initialized and no location was specified
 
 - 
getPofConfigprotected ConfigurablePofContext.PofConfig getPofConfig() Obtain the PofConfig that represents the initialized state of the ConfigurablePofContext.- Returns:
- the PofConfig for the ConfigurablePofContext, or null if not yet initialized
 
 - 
isInterfaceAllowedprotected boolean isInterfaceAllowed() Determine if the ConfigurablePofContext supports the configuration of user types by specifying an interface (instead of a class) for the Java type.- Returns:
- true iff an interface name is acceptable in the configuration as the class of a user type
 
 - 
isSubclassAllowedprotected boolean isSubclassAllowed() Determine if the ConfigurablePofContext supports the serialization of an object that is an instance of a sub-class of a configured type, but not actually an instance of a class of a configured type.- Returns:
- true iff serialization of sub-classes is explicitly enabled
 
 - 
isLambdaAllowedprotected boolean isLambdaAllowed() Determine if implicit root lambda class processing is allowed.- Returns:
- true iff implicit root lambda class processing is allowed.
 
 - 
isReferenceEnabledpublic boolean isReferenceEnabled() Determine if Identity/Reference type support is enabled for this ConfigurablePofContext.- Returns:
- true if Identity/Reference type support is enabled
 
 - 
setReferenceEnabledpublic void setReferenceEnabled(boolean fReferenceEnabled) Set the referenceEnabled flag.- Parameters:
- fReferenceEnabled- the referenceEnabled flag to set
 
 - 
setPreferJavaTimepublic void setPreferJavaTime(boolean fPreferJavaTime) Set the flag specifying if Java 8 date/time types (java.time.*) should be preferred over legacy types.- Parameters:
- fPreferJavaTime- whether Java 8 data/time types
 
 - 
setIndexFileNamepublic void setIndexFileName(String sIndexFile) Set the Jandex index file name to use to discover portable types.- Parameters:
- sIndexFile- Jandex index file name to use to discover portable types
 
 - 
getIndexFileNamepublic String getIndexFileName() Return the Jandex index file name to use to discover portable types.- Returns:
- the Jandex index file name to use to discover portable types
 
 - 
toStringpublic String toString() Return a description of this ConfigurablePofContext.
 - 
checkNotInitializedprotected void checkNotInitialized() Verify that the ConfigurablePofContext has not already been initialized.- Throws:
- IllegalStateException- if the ConfigurablePofContext is already fully initialized
 
 - 
ensureInitializedprotected void ensureInitialized() Fully initialize the ConfigurablePofContext if it has not already been initialized.
 - 
initializeprotected void initialize() Bind the ConfigurablePofContext to a ClassLoader, resolving all class names, etc.
 - 
createPofConfigprotected ConfigurablePofContext.PofConfig createPofConfig() Create a PofConfig object based on a configuration that was either provided as XML, or can be loaded from the specified (or default) URI using the provided ClassLoader.- Returns:
- a PofConfig for this ConfigurablePofContext
 
 - 
instantiateSerializerprotected PofSerializer instantiateSerializer(XmlElement xmlSer, int nTypeId, Class clz) Create aPofSerializerfrom the provided XML serializer element.- Parameters:
- xmlSer- xml defining the serializer to create
- nTypeId- the user type id this class is registered with
- clz- the class of the user type
- Returns:
- a PofSerializer implementation capable of (de)serializing clz
 
 - 
instantiateSerializerprotected PofSerializer<?> instantiateSerializer(Class<? extends PofSerializer> clzSer, Integer nTypeId, Class<?> clz) Instantiate specifiedPofSerializer.- Parameters:
- clzSer- the class of the serializer to create
- nTypeId- the user type id this class is registered with
- clz- the class of the user type
- Returns:
- a PofSerializer implementation capable of (de)serializing clz
 
 - 
loadClassprotected Class loadClass(String sClass) Find the specified class, return a Java Class object for it.- Parameters:
- sClass- the fully qualified class name
- Returns:
- the Class object for the specified class name, never null
- Throws:
- RuntimeException- a RuntimeException (or a subclass thereof) is thrown if the specified Class could not be loaded
 
 - 
reportprotected void report(String sURI, int nTypeId, String sClass, Throwable e, String sText) Assemble and throw an informative exception based on the passed details.- Parameters:
- sURI- the URI of the configuration
- nTypeId- the type ID (if applicable and if known)
- sClass- the user type class name (if applicable and if known)
- e- the underlying exception, if any
- sText- the detailed description of the problem
- Throws:
- IllegalStateException- always thrown
 
 - 
mergeIncludespublic static void mergeIncludes(String sURI, XmlElement xmlConfig, ClassLoader loader) Merge all included POF configuration files into the given xml configuration.- Parameters:
- sURI- the URI of the POF configuration file
- xmlConfig- the base POF configuration
- loader- the- ClassLoaderused to find the included POF configuration resources
 
 - 
appendDefaultSerializerToUserTypesprotected static void appendDefaultSerializerToUserTypes(XmlElement xmlConfig) Process <default-serializer> element from the specified xml configuration and append information about the serializer to each <user-type> element within <user-type-list> unless user type already has a serializer specified.This method could be overridden to add new custom configuration elements to pof-config. - Parameters:
- xmlConfig- the XmlElement containing pof configuration
 
 
- 
 
-