All Downloads are FREE. Search and download functionalities are using the official Maven repository.

parquet.org.codehaus.jackson.map.deser.BeanDeserializerModifier Maven / Gradle / Ivy

package com.facebook.presto.hive.$internal.org.codehaus.jackson.map.deser;

import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.DeserializationConfig;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.JsonDeserializer;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.deser.BeanDeserializer;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.deser.BeanDeserializerFactory;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.introspect.BasicBeanDescription;

/**
 * Abstract class that defines API for objects that can be registered (for {@link BeanDeserializerFactory}
 * to participate in constructing {@link BeanDeserializer} instances.
 * This is typically done by modules that want alter some aspects of deserialization
 * process; and is preferable to sub-classing of {@link BeanDeserializerFactory}.
 *

* Sequence in which callback methods are called is as follows: *

  • updateBuilder is called once all initial pieces for building deserializer * have been collected *
  • *
  • modifyDeserializer is called after deserializer has been built * by {@link BeanDeserializerBuilder} * but before it is returned to be used *
  • * *

    * Default method implementations are "no-op"s, meaning that methods are implemented * but have no effect; this is mostly so that new methods can be added in later * versions. * * @since 1.7 */ public abstract class BeanDeserializerModifier { /** * Method called by {@link BeanDeserializerFactory} when it has collected * basic information such as tentative list of properties to deserialize. * * Implementations may choose to modify state of builder (to affect deserializer being * built), or even completely replace it (if they want to build different kind of * deserializer). Typically changes mostly concern set of properties to deserialize. */ public BeanDeserializerBuilder updateBuilder(DeserializationConfig config, BasicBeanDescription beanDesc, BeanDeserializerBuilder builder) { return builder; } /** * Method called by {@link BeanDeserializerFactory} after constructing default * bean deserializer instance with properties collected and ordered earlier. * Implementations can modify or replace given deserializer and return deserializer * to use. Note that although initial deserializer being passed is of type * {@link BeanDeserializer}, modifiers may return deserializers of other types; * and this is why implementations must check for type before casting. */ public JsonDeserializer modifyDeserializer(DeserializationConfig config, BasicBeanDescription beanDesc, JsonDeserializer deserializer) { return deserializer; } }





    © 2015 - 2025 Weber Informatics LLC | Privacy Policy