package sh.calaba.org.codehaus.jackson.map.deser.std;
import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import java.util.*;
import sh.calaba.org.codehaus.jackson.map.DeserializationConfig;
import sh.calaba.org.codehaus.jackson.map.KeyDeserializer;
import sh.calaba.org.codehaus.jackson.map.introspect.AnnotatedMethod;
import sh.calaba.org.codehaus.jackson.map.introspect.BasicBeanDescription;
import sh.calaba.org.codehaus.jackson.map.type.*;
import sh.calaba.org.codehaus.jackson.map.util.ClassUtil;
import sh.calaba.org.codehaus.jackson.map.util.EnumResolver;
import sh.calaba.org.codehaus.jackson.type.JavaType;
/**
* Helper class used to contain simple/well-known key deserializers.
* Following kinds of Objects can be handled currently:
*
* - Primitive wrappers
* - Enums (usually not needed, since EnumMap doesn't call us)
* - Anything with constructor that takes a single String arg
* (if not explicitly @JsonIgnore'd)
* - Anything with 'static T valueOf(String)' factory method
* (if not explicitly @JsonIgnore'd)
*
*/
public class StdKeyDeserializers
{
protected final HashMap _keyDeserializers = new HashMap();
protected StdKeyDeserializers()
{
add(new StdKeyDeserializer.BoolKD());
add(new StdKeyDeserializer.ByteKD());
add(new StdKeyDeserializer.CharKD());
add(new StdKeyDeserializer.ShortKD());
add(new StdKeyDeserializer.IntKD());
add(new StdKeyDeserializer.LongKD());
add(new StdKeyDeserializer.FloatKD());
add(new StdKeyDeserializer.DoubleKD());
add(new StdKeyDeserializer.DateKD());
add(new StdKeyDeserializer.CalendarKD());
add(new StdKeyDeserializer.UuidKD());
}
private void add(StdKeyDeserializer kdeser)
{
Class> keyClass = kdeser.getKeyClass();
/* As with other cases involving primitive types, we can use
* default TypeFactory ok, even if it's not our first choice:
*/
_keyDeserializers.put(TypeFactory.defaultInstance().uncheckedSimpleType(keyClass), kdeser);
}
public static HashMap constructAll()
{
return new StdKeyDeserializers()._keyDeserializers;
}
/*
/**********************************************************
/* Factory methods
/**********************************************************
*/
public static KeyDeserializer constructStringKeyDeserializer(DeserializationConfig config, JavaType type)
{
return StdKeyDeserializer.StringKD.forType(type.getClass());
}
public static KeyDeserializer constructEnumKeyDeserializer(EnumResolver> enumResolver) {
return new StdKeyDeserializer.EnumKD(enumResolver, null);
}
public static KeyDeserializer constructEnumKeyDeserializer(EnumResolver> enumResolver,
AnnotatedMethod factory) {
return new StdKeyDeserializer.EnumKD(enumResolver, factory);
}
public static KeyDeserializer findStringBasedKeyDeserializer(DeserializationConfig config, JavaType type)
{
/* We don't need full deserialization information, just need to
* know creators.
*/
BasicBeanDescription beanDesc = config.introspect(type);
// Ok, so: can we find T(String) constructor?
Constructor> ctor = beanDesc.findSingleArgConstructor(String.class);
if (ctor != null) {
if (config.isEnabled(DeserializationConfig.Feature.CAN_OVERRIDE_ACCESS_MODIFIERS)) {
ClassUtil.checkAndFixAccess(ctor);
}
return new StdKeyDeserializer.StringCtorKeyDeserializer(ctor);
}
/* or if not, "static T valueOf(String)" (or equivalent marked
* with @JsonCreator annotation?)
*/
Method m = beanDesc.findFactoryMethod(String.class);
if (m != null){
if (config.isEnabled(DeserializationConfig.Feature.CAN_OVERRIDE_ACCESS_MODIFIERS)) {
ClassUtil.checkAndFixAccess(m);
}
return new StdKeyDeserializer.StringFactoryKeyDeserializer(m);
}
// nope, no such luck...
return null;
}
}