com.arangodb.shaded.fasterxml.jackson.databind.ser.std.StdScalarSerializer Maven / Gradle / Ivy
package com.arangodb.shaded.fasterxml.jackson.databind.ser.std;
import java.io.IOException;
import java.lang.reflect.Type;
import com.arangodb.shaded.fasterxml.jackson.core.*;
import com.arangodb.shaded.fasterxml.jackson.core.type.WritableTypeId;
import com.arangodb.shaded.fasterxml.jackson.databind.JavaType;
import com.arangodb.shaded.fasterxml.jackson.databind.JsonMappingException;
import com.arangodb.shaded.fasterxml.jackson.databind.JsonNode;
import com.arangodb.shaded.fasterxml.jackson.databind.SerializerProvider;
import com.arangodb.shaded.fasterxml.jackson.databind.jsonFormatVisitors.JsonFormatVisitorWrapper;
import com.arangodb.shaded.fasterxml.jackson.databind.jsontype.TypeSerializer;
@SuppressWarnings("serial")
public abstract class StdScalarSerializer
extends StdSerializer
{
protected StdScalarSerializer(Class t) {
super(t);
}
/**
* Alternate constructor that is (alas!) needed to work
* around kinks of generic type handling
*/
@SuppressWarnings("unchecked")
protected StdScalarSerializer(Class> t, boolean dummy) {
super((Class) t);
}
/**
* Basic copy-constructor
*
* @param src Original instance to copy settings from
*
* @since 2.12
*/
protected StdScalarSerializer(StdScalarSerializer> src) {
super(src);
}
/**
* 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 g, SerializerProvider provider,
TypeSerializer typeSer) throws IOException
{
// NOTE: need not really be string; just indicates "scalar of some kind"
WritableTypeId typeIdDef = typeSer.writeTypePrefix(g,
typeSer.typeId(value, JsonToken.VALUE_STRING));
serialize(value, g, provider);
typeSer.writeTypeSuffix(g, typeIdDef);
}
@Override
public JsonNode getSchema(SerializerProvider provider, Type typeHint)
throws JsonMappingException
{
return createSchemaNode("string", true);
}
@Override
public void acceptJsonFormatVisitor(JsonFormatVisitorWrapper visitor, JavaType typeHint)
throws JsonMappingException
{
// 13-Sep-2013, tatu: Let's assume it's usually a String, right?
visitStringFormat(visitor, typeHint);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy