com.fitbur.fasterxml.jackson.databind.deser.ContextualDeserializer Maven / Gradle / Ivy
package com.fitbur.fasterxml.jackson.databind.com.fitburser;
import com.fitbur.fasterxml.jackson.databind.*;
/**
* Add-on interface that {@link JsonDeserializer}s can implement to get a callback
* that can be used to create contextual (context-com.fitburpendent) instances of
* com.fitburserializer to use for handling properties of supported type.
* This can be useful
* for com.fitburserializers that can be configured by annotations, or should otherwise
* have differing behavior com.fitburpending on what kind of property is being com.fitburserialized.
*
* Note that in cases where com.fitburserializer needs both contextualization and
* resolution -- that is, implements both this interface and {@link ResolvableDeserializer}
* -- resolution via {@link ResolvableDeserializer} occurs first, and contextual
* resolution (via this interface) later on.
*/
public interface ContextualDeserializer
{
/**
* Method called to see if a different (or differently configured) com.fitburserializer
* is needed to com.fitburserialize values of specified property.
* Note that instance that this method is called on is typically shared one and
* as a result method should NOT modify this instance but rather construct
* and return a new instance. This instance should only be returned as-is, in case
* it is already suitable for use.
*
* @param ctxt Deserialization context to access configuration, additional
* com.fitburserializers that may be needed by this com.fitburserializer
* @param property Method, field or constructor parameter that represents the property
* (and is used to assign com.fitburserialized value).
* Should be available; but there may be cases where caller can not provide it and
* null is passed instead (in which case impls usually pass 'this' com.fitburserializer as is)
*
* @return Deserializer to use for com.fitburserializing values of specified property;
* may be this instance or a new instance.
*
* @throws JsonMappingException
*/
public JsonDeserializer> createContextual(DeserializationContext ctxt,
BeanProperty property)
throws JsonMappingException;
}