blob: af53043d07e95fa80bd64505aee739e7516173d4 [file] [log] [blame]
package org.codehaus.jackson.map.ser.std;
import java.io.IOException;
import java.util.*;
import org.codehaus.jackson.JsonGenerationException;
import org.codehaus.jackson.JsonGenerator;
import org.codehaus.jackson.JsonNode;
import org.codehaus.jackson.map.BeanProperty;
import org.codehaus.jackson.map.JsonMappingException;
import org.codehaus.jackson.map.JsonSerializer;
import org.codehaus.jackson.map.ResolvableSerializer;
import org.codehaus.jackson.map.SerializerProvider;
import org.codehaus.jackson.map.TypeSerializer;
import org.codehaus.jackson.map.annotate.JacksonStdImpl;
/**
* Efficient implementation for serializing {@link List}s that contains Strings and are random-accessible.
* 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
public final class IndexedStringListSerializer
extends StaticListSerializerBase<List<String>>
implements ResolvableSerializer
{
protected JsonSerializer<String> _serializer;
public IndexedStringListSerializer(BeanProperty property) {
this(property, null);
}
@SuppressWarnings("unchecked")
public IndexedStringListSerializer(BeanProperty property, JsonSerializer<?> ser) {
super(List.class, property);
_serializer = (JsonSerializer<String>) ser;
}
@Override protected JsonNode contentSchema() {
return createSchemaNode("string", true);
}
@SuppressWarnings("unchecked")
@Override
public void resolve(SerializerProvider provider) throws JsonMappingException
{
if (_serializer == null) {
JsonSerializer<?> ser = provider.findValueSerializer(String.class, _property);
if (!isDefaultSerializer(ser)) {
_serializer = (JsonSerializer<String>) ser;
}
}
}
@Override
public void serialize(List<String> value, JsonGenerator jgen, SerializerProvider provider)
throws IOException, JsonGenerationException
{
jgen.writeStartArray();
if (_serializer == null) {
serializeContents(value, jgen, provider);
} else {
serializeUsingCustom(value, jgen, provider);
}
jgen.writeEndArray();
}
@Override
public void serializeWithType(List<String> value, JsonGenerator jgen, SerializerProvider provider,
TypeSerializer typeSer)
throws IOException, JsonGenerationException
{
typeSer.writeTypePrefixForArray(value, jgen);
if (_serializer == null) {
serializeContents(value, jgen, provider);
} else {
serializeUsingCustom(value, jgen, provider);
}
typeSer.writeTypeSuffixForArray(value, jgen);
}
private final void serializeContents(List<String> value, JsonGenerator jgen, SerializerProvider provider)
throws IOException, JsonGenerationException
{
int i = 0;
try {
final int len = value.size();
for (; i < len; ++i) {
String str = value.get(i);
if (str == null) {
provider.defaultSerializeNull(jgen);
} else {
jgen.writeString(str);
}
}
} catch (Exception e) {
wrapAndThrow(provider, e, value, i);
}
}
private final void serializeUsingCustom(List<String> value, JsonGenerator jgen, SerializerProvider provider)
throws IOException, JsonGenerationException
{
int i = 0;
try {
final int len = value.size();
final JsonSerializer<String> ser = _serializer;
for (i = 0; i < len; ++i) {
String str = value.get(i);
if (str == null) {
provider.defaultSerializeNull(jgen);
} else {
ser.serialize(str, jgen, provider);
}
}
} catch (Exception e) {
wrapAndThrow(provider, e, value, i);
}
}
}