parquet.org.codehaus.jackson.map.ser.std.ScalarSerializerBase Maven / Gradle / Ivy
package com.facebook.presto.hive.$internal.org.codehaus.jackson.map.ser.std;
import java.io.IOException;
import java.lang.reflect.Type;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.JsonGenerationException;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.JsonGenerator;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.JsonNode;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.JsonMappingException;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.SerializerProvider;
import com.facebook.presto.hive.$internal.org.codehaus.jackson.map.TypeSerializer;
public abstract class ScalarSerializerBase
extends SerializerBase
{
protected ScalarSerializerBase(Class t) {
super(t);
}
/**
* Alternate constructor that is (alas!) needed to work
* around kinks of generic type handling
*/
@SuppressWarnings("unchecked")
protected ScalarSerializerBase(Class> t, boolean dummy) {
super((Class) t);
}
/**
* Default implementation will write type prefix, call regular serialization
* method (since assumption is that value itself does not need JSON
* Array or Object start/end markers), and then write type suffix.
* This should work for most cases; some sub-classes may want to
* change this behavior.
*/
@Override
public void serializeWithType(T value, JsonGenerator jgen, SerializerProvider provider,
TypeSerializer typeSer)
throws IOException, JsonGenerationException
{
typeSer.writeTypePrefixForScalar(value, jgen);
serialize(value, jgen, provider);
typeSer.writeTypeSuffixForScalar(value, jgen);
}
@Override
public JsonNode getSchema(SerializerProvider provider, Type typeHint)
throws JsonMappingException
{
return createSchemaNode("string", true);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy