public abstract class TypeDeserializer
extends java.lang.Object
Separate deserialization methods are needed because serialized
form for inclusion mechanism JsonTypeInfo.As.PROPERTY
is slighty different if value is not expressed as JSON Object:
and as such both type deserializer and serializer need to
JSON Object form (array, object or other (== scalar)) being used.
Constructor and Description |
---|
TypeDeserializer() |
Modifier and Type | Method and Description |
---|---|
static java.lang.Object |
deserializeIfNatural(JsonParser p,
DeserializationContext ctxt,
java.lang.Class<?> base) |
static java.lang.Object |
deserializeIfNatural(JsonParser p,
DeserializationContext ctxt,
JavaType baseType)
Helper method used to check if given parser might be pointing to
a "natural" value, and one that would be acceptable as the
result value (compatible with declared base type)
|
abstract java.lang.Object |
deserializeTypedFromAny(JsonParser p,
DeserializationContext ctxt)
Method called to let this type deserializer handle
deserialization of "typed" object, when value itself
may have been serialized using any kind of JSON value
(Array, Object, scalar).
|
abstract java.lang.Object |
deserializeTypedFromArray(JsonParser p,
DeserializationContext ctxt)
Method called to let this type deserializer handle
deserialization of "typed" object, when value itself
is serialized as JSON Array (regardless of Java type).
|
abstract java.lang.Object |
deserializeTypedFromObject(JsonParser p,
DeserializationContext ctxt)
Method called to let this type deserializer handle
deserialization of "typed" object, when value itself
is serialized as JSON Object (regardless of Java type).
|
abstract java.lang.Object |
deserializeTypedFromScalar(JsonParser p,
DeserializationContext ctxt)
Method called to let this type deserializer handle
deserialization of "typed" object, when value itself
is serialized as a scalar JSON value (something other
than Array or Object), regardless of Java type.
|
abstract TypeDeserializer |
forProperty(BeanProperty prop)
Method called to create contextual version, to be used for
values of given property.
|
abstract java.lang.Class<?> |
getDefaultImpl()
Accessor for "default implementation" type; optionally defined
class to use in cases where type id is not
accessible for some reason (either missing, or cannot be
resolved)
|
abstract java.lang.String |
getPropertyName()
Name of property that contains type information, if
property-based inclusion is used.
|
abstract TypeIdResolver |
getTypeIdResolver()
Accessor for object that handles conversions between
types and matching type ids.
|
abstract JsonTypeInfo.As |
getTypeInclusion()
Accessor for type information inclusion method
that deserializer uses; indicates how type information
is (expected to be) embedded in JSON input.
|
public abstract TypeDeserializer forProperty(BeanProperty prop)
Collection
or Map
valued properties).public abstract JsonTypeInfo.As getTypeInclusion()
public abstract java.lang.String getPropertyName()
public abstract TypeIdResolver getTypeIdResolver()
public abstract java.lang.Class<?> getDefaultImpl()
public abstract java.lang.Object deserializeTypedFromObject(JsonParser p, DeserializationContext ctxt) throws java.io.IOException
JsonDeserializer
to use, and
call it with JSON data to deserializer (which does not contain
type information).java.io.IOException
public abstract java.lang.Object deserializeTypedFromArray(JsonParser p, DeserializationContext ctxt) throws java.io.IOException
JsonDeserializer
to use, and
call it with JSON data to deserializer (which does not contain
type information).java.io.IOException
public abstract java.lang.Object deserializeTypedFromScalar(JsonParser p, DeserializationContext ctxt) throws java.io.IOException
JsonDeserializer
to use, and
call it with JSON data to deserializer (which does not contain
type information).java.io.IOException
public abstract java.lang.Object deserializeTypedFromAny(JsonParser p, DeserializationContext ctxt) throws java.io.IOException
java.io.IOException
public static java.lang.Object deserializeIfNatural(JsonParser p, DeserializationContext ctxt, JavaType baseType) throws java.io.IOException
java.io.IOException
public static java.lang.Object deserializeIfNatural(JsonParser p, DeserializationContext ctxt, java.lang.Class<?> base) throws java.io.IOException
java.io.IOException
Copyright © 2010 - 2020 Adobe. All Rights Reserved