com.sun.xml.bind.v2.model.impl
Class RuntimeBuiltinLeafInfoImpl<T>
java.lang.Object
com.sun.xml.bind.v2.model.impl.LeafInfoImpl<TypeT,ClassDeclT>
com.sun.xml.bind.v2.model.impl.BuiltinLeafInfoImpl<java.lang.reflect.Type,java.lang.Class>
com.sun.xml.bind.v2.model.impl.RuntimeBuiltinLeafInfoImpl<T>
- All Implemented Interfaces:
- Locatable, BuiltinLeafInfo<java.lang.reflect.Type,java.lang.Class>, LeafInfo<java.lang.reflect.Type,java.lang.Class>, MaybeElement<java.lang.reflect.Type,java.lang.Class>, NonElement<java.lang.reflect.Type,java.lang.Class>, TypeInfo<java.lang.reflect.Type,java.lang.Class>, RuntimeBuiltinLeafInfo, RuntimeLeafInfo, RuntimeNonElement, RuntimeTypeInfo, Location, Transducer<T>
public abstract class RuntimeBuiltinLeafInfoImpl<T>
- extends BuiltinLeafInfoImpl<java.lang.reflect.Type,java.lang.Class>
- implements RuntimeBuiltinLeafInfo, Transducer<T>
BuiltinLeafInfoImpl with a support for runtime.
In particular this class defines Transducers for the built-in types.
| Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
LEAVES
public static final java.util.Map<java.lang.reflect.Type,RuntimeBuiltinLeafInfoImpl<?>> LEAVES
- All instances of
RuntimeBuiltinLeafInfoImpls keyed by their type.
STRING
public static final RuntimeBuiltinLeafInfoImpl<java.lang.String> STRING
builtinBeanInfos
public static final java.util.List<RuntimeBuiltinLeafInfoImpl<?>> builtinBeanInfos
- List of all
RuntimeBuiltinLeafInfoImpls.
This corresponds to the built-in Java classes that are specified to be
handled differently than ordinary classes. See table 8-2 "Mapping of Standard Java classes".
MAP_ANYURI_TO_URI
public static final java.lang.String MAP_ANYURI_TO_URI
- See Also:
- Constant Field Values
getClazz
public final java.lang.Class getClazz()
- Description copied from interface:
RuntimeLeafInfo
- The same as
TypeInfo.getType() but returns the type as a Class.
Note that the returned Class object does not necessarily represents
a class declaration. It can be primitive types.
- Specified by:
getClazz in interface RuntimeLeafInfo
getTransducer
public final Transducer getTransducer()
- Description copied from interface:
RuntimeLeafInfo
- This method doesn't take the reference properties defined on
RuntimeNonElementRef into account (such as ID-ness.)
- Specified by:
getTransducer in interface RuntimeLeafInfo- Specified by:
getTransducer in interface RuntimeNonElement
- Returns:
- always non-null.
- See Also:
RuntimeNonElementRef.getTransducer()
useNamespace
public boolean useNamespace()
- Description copied from interface:
Transducer
- If true, this
Transducer doesn't declare any namespace,
and therefore Transducer.declareNamespace(Object, XMLSerializer) is no-op.
It also means that the Transducer.parse(CharSequence) method
won't use the context parameter.
- Specified by:
useNamespace in interface Transducer<T>
isDefault
public final boolean isDefault()
- Description copied from interface:
Transducer
- If this
Transducer is the default transducer for the ValueT,
this method returns true.
Used exclusively by OptimizedTransducedAccessorFactory.get(RuntimePropertyInfo)
- Specified by:
isDefault in interface Transducer<T>
declareNamespace
public void declareNamespace(T o,
XMLSerializer w)
throws AccessorException
- Description copied from interface:
Transducer
- Declares the namespace URIs used in the given value to
w.
- Specified by:
declareNamespace in interface Transducer<T>
- Parameters:
o - never be null.w - may be null if !{@link #useNamespace()}.
- Throws:
AccessorException
getTypeName
public javax.xml.namespace.QName getTypeName(T instance)
- Description copied from interface:
Transducer
- Transducers implicitly work against a single XML type,
but sometimes (most notably
XMLGregorianCalendar,
an instance may choose different XML types.
- Specified by:
getTypeName in interface Transducer<T>
- Returns:
- return non-null from this method allows transducers
to specify the type it wants to marshal to.
Most of the time this method returns null, in which case
the implicitly associated type will be used.