public abstract class TypeDeserializer extends 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 Object |
deserializeIfNatural(JsonParser p,
DeserializationContext ctxt,
Class<?> base) |
static 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 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 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 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 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 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 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 String getPropertyName()
public abstract TypeIdResolver getTypeIdResolver()
public abstract Class<?> getDefaultImpl()
public abstract Object deserializeTypedFromObject(JsonParser p, DeserializationContext ctxt) throws IOException
JsonDeserializer
to use, and
call it with JSON data to deserializer (which does not contain
type information).IOException
public abstract Object deserializeTypedFromArray(JsonParser p, DeserializationContext ctxt) throws IOException
JsonDeserializer
to use, and
call it with JSON data to deserializer (which does not contain
type information).IOException
public abstract Object deserializeTypedFromScalar(JsonParser p, DeserializationContext ctxt) throws IOException
JsonDeserializer
to use, and
call it with JSON data to deserializer (which does not contain
type information).IOException
public abstract Object deserializeTypedFromAny(JsonParser p, DeserializationContext ctxt) throws IOException
IOException
public static Object deserializeIfNatural(JsonParser p, DeserializationContext ctxt, JavaType baseType) throws IOException
IOException
public static Object deserializeIfNatural(JsonParser p, DeserializationContext ctxt, Class<?> base) throws IOException
IOException
Copyright © 2008–2020 FasterXML. All rights reserved.