io.prestosql.jdbc.$internal.jackson.databind.ser.impl.StringCollectionSerializer Maven / Gradle / Ivy
package io.prestosql.jdbc.$internal.jackson.databind.ser.impl;
import java.io.IOException;
import java.util.*;
import io.prestosql.jdbc.$internal.jackson.core.*;
import io.prestosql.jdbc.$internal.jackson.core.type.WritableTypeId;
import io.prestosql.jdbc.$internal.jackson.databind.*;
import io.prestosql.jdbc.$internal.jackson.databind.annotation.JacksonStdImpl;
import io.prestosql.jdbc.$internal.jackson.databind.jsonFormatVisitors.JsonArrayFormatVisitor;
import io.prestosql.jdbc.$internal.jackson.databind.jsonFormatVisitors.JsonFormatTypes;
import io.prestosql.jdbc.$internal.jackson.databind.jsontype.TypeSerializer;
import io.prestosql.jdbc.$internal.jackson.databind.ser.std.StaticListSerializerBase;
/**
* Efficient implement for serializing {@link Collection}s that contain Strings.
* The only complexity is due to possibility that serializer for {@link String}
* may be overridde; because of this, logic is needed to ensure that the default
* serializer is in use to use fastest mode, or if not, to defer to custom
* String serializer.
*/
@JacksonStdImpl
@SuppressWarnings("serial")
public class StringCollectionSerializer
extends StaticListSerializerBase>
{
public final static StringCollectionSerializer instance = new StringCollectionSerializer();
/*
/**********************************************************
/* Life-cycle
/**********************************************************
*/
protected StringCollectionSerializer() {
super(Collection.class);
}
protected StringCollectionSerializer(StringCollectionSerializer src,
Boolean unwrapSingle)
{
super(src, unwrapSingle);
}
@Override
public JsonSerializer> _withResolved(BeanProperty prop, Boolean unwrapSingle) {
return new StringCollectionSerializer(this, unwrapSingle);
}
@Override protected JsonNode contentSchema() {
return createSchemaNode("string", true);
}
@Override
protected void acceptContentVisitor(JsonArrayFormatVisitor visitor) throws JsonMappingException
{
visitor.itemsFormat(JsonFormatTypes.STRING);
}
/*
/**********************************************************
/* Actual serialization
/**********************************************************
*/
@Override
public void serialize(Collection value, JsonGenerator g,
SerializerProvider provider) throws IOException
{
g.setCurrentValue(value);
final int len = value.size();
if (len == 1) {
if (((_unwrapSingle == null) &&
provider.isEnabled(SerializationFeature.WRITE_SINGLE_ELEM_ARRAYS_UNWRAPPED))
|| (_unwrapSingle == Boolean.TRUE)) {
serializeContents(value, g, provider);
return;
}
}
g.writeStartArray(len);
serializeContents(value, g, provider);
g.writeEndArray();
}
@Override
public void serializeWithType(Collection value, JsonGenerator g,
SerializerProvider provider, TypeSerializer typeSer)
throws IOException
{
g.setCurrentValue(value);
WritableTypeId typeIdDef = typeSer.writeTypePrefix(g,
typeSer.typeId(value, JsonToken.START_ARRAY));
serializeContents(value, g, provider);
typeSer.writeTypeSuffix(g, typeIdDef);
}
private final void serializeContents(Collection value, JsonGenerator g,
SerializerProvider provider)
throws IOException
{
int i = 0;
try {
for (String str : value) {
if (str == null) {
provider.defaultSerializeNull(g);
} else {
g.writeString(str);
}
++i;
}
} catch (Exception e) {
wrapAndThrow(provider, e, value, i);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy