Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
external.com.alibaba.fastjson.parser.MapDeserializer Maven / Gradle / Ivy
Go to download
ratel api,used for developer on ratel system,an extension for xposed framewrok,ratel api compatable with original xposed framework
package external.com.alibaba.fastjson.parser;
import java.lang.reflect.Constructor;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
import external.com.alibaba.fastjson.JSON;
import external.com.alibaba.fastjson.JSONException;
import external.com.alibaba.fastjson.JSONObject;
import external.com.alibaba.fastjson.parser.DefaultJSONParser.ResolveTask;
import external.com.alibaba.fastjson.parser.deserializer.ObjectDeserializer;
import external.com.alibaba.fastjson.util.TypeUtils;
class MapDeserializer implements ObjectDeserializer {
public static MapDeserializer instance = new MapDeserializer();
@SuppressWarnings("unchecked")
public T deserialze(DefaultJSONParser parser, Type type, Object fieldName) {
if (type == JSONObject.class && parser.fieldTypeResolver == null) {
return (T) parser.parseObject();
}
final JSONLexer lexer = parser.lexer;
if (lexer.token == JSONToken.NULL) {
lexer.nextToken(JSONToken.COMMA);
return null;
}
Map, ?> map = createMap(type);
ParseContext context = parser.contex;
try {
parser.setContext(context, map, fieldName);
if (type instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) type;
Type keyType = parameterizedType.getActualTypeArguments()[0];
Type valueType = parameterizedType.getActualTypeArguments()[1];
if (String.class == keyType) {
return (T) parseMap(parser, (Map) map, valueType, fieldName);
} else {
return (T) parseMap(parser, (Map) map, keyType, valueType, fieldName);
}
} else {
return (T) parser.parseObject(map, fieldName);
}
} finally {
parser.setContext(context);
}
}
@SuppressWarnings("rawtypes")
public static Map parseMap(DefaultJSONParser parser, Map map, Type valueType, Object fieldName) {
JSONLexer lexer = parser.lexer;
if (lexer.token != JSONToken.LBRACE) {
throw new JSONException("syntax error, expect {, actual " + lexer.token);
}
ParseContext context = parser.contex;
try {
for (;;) {
lexer.skipWhitespace();
char ch = lexer.ch;
while (ch == ',') {
lexer.next();
lexer.skipWhitespace();
ch = lexer.ch;
}
String key;
if (ch == '"') {
key = lexer.scanSymbol(parser.symbolTable, '"');
lexer.skipWhitespace();
ch = lexer.ch;
if (ch != ':') {
throw new JSONException("syntax error, " + lexer.info());
}
} else if (ch == '}') {
lexer.next();
lexer.sp = 0;
lexer.nextToken(JSONToken.COMMA);
return map;
} else if (ch == '\'') {
key = lexer.scanSymbol(parser.symbolTable, '\'');
lexer.skipWhitespace();
ch = lexer.ch;
if (ch != ':') {
throw new JSONException("syntax error, " + lexer.info());
}
} else {
key = lexer.scanSymbolUnQuoted(parser.symbolTable);
lexer.skipWhitespace();
ch = lexer.ch;
if (ch != ':') {
throw new JSONException("expect ':' at " + lexer.pos + ", actual " + ch);
}
}
lexer.next();
lexer.skipWhitespace();
ch = lexer.ch;
lexer.sp = 0;
if (key == JSON.DEFAULT_TYPE_KEY && !lexer.isEnabled(Feature.DisableSpecialKeyDetect)) {
String typeName = lexer.scanSymbol(parser.symbolTable, '"');
Class> clazz = parser.config.checkAutoType(typeName, null, lexer.features);
if (clazz == map.getClass()) {
lexer.nextToken(JSONToken.COMMA);
if (lexer.token == JSONToken.RBRACE) {
lexer.nextToken(JSONToken.COMMA);
return map;
}
continue;
}
ObjectDeserializer deserializer = parser.config.getDeserializer(clazz);
lexer.nextToken(JSONToken.COMMA);
parser.resolveStatus = DefaultJSONParser.TypeNameRedirect;
if (context != null && !(fieldName instanceof Integer)) {
parser.popContext();
}
return (Map) deserializer.deserialze(parser, clazz, fieldName);
}
Object value;
lexer.nextToken();
parser.setContext(context);
if (lexer.token == JSONToken.NULL) {
value = null;
lexer.nextToken();
} else {
value = parser.parseObject(valueType, key);
}
map.put(key, value);
if (parser.resolveStatus == DefaultJSONParser.NeedToResolve) {
parser.checkMapResolve(map, key);
}
parser.setContext(context, value, key);
final int tok = lexer.token;
if (tok == JSONToken.EOF || tok == JSONToken.RBRACKET) {
return map;
}
if (tok == JSONToken.RBRACE) {
lexer.nextToken();
return map;
}
}
} finally {
parser.setContext(context);
}
}
public static Object parseMap(DefaultJSONParser parser, Map map, Type keyType, Type valueType,
Object fieldName) {
JSONLexer lexer = parser.lexer;
int token = lexer.token;
if (token != JSONToken.LBRACE && token != JSONToken.COMMA) {
throw new JSONException("syntax error, expect {, actual " + JSONToken.name(token));
}
ObjectDeserializer keyDeserializer = parser.config.getDeserializer(keyType);
ObjectDeserializer valueDeserializer = parser.config.getDeserializer(valueType);
lexer.nextToken();
ParseContext context = parser.contex;
try {
for (;;) {
token = lexer.token;
if (token == JSONToken.RBRACE) {
lexer.nextToken(JSONToken.COMMA);
break;
}
if (token == JSONToken.LITERAL_STRING //
&& (lexer.sp == 4 && lexer.text.startsWith("$ref", lexer.np + 1)) // isRef
&& !lexer.isEnabled(Feature.DisableSpecialKeyDetect)) {
Object object = null;
lexer.nextTokenWithChar(':');
if (lexer.token == JSONToken.LITERAL_STRING) {
String ref = lexer.stringVal();
if ("..".equals(ref)) {
ParseContext parentContext = context.parent;
object = parentContext.object;
} else if ("$".equals(ref)) {
ParseContext rootContext = context;
while (rootContext.parent != null) {
rootContext = rootContext.parent;
}
object = rootContext.object;
} else {
parser.addResolveTask(new ResolveTask(context, ref));
parser.resolveStatus = DefaultJSONParser.NeedToResolve;
}
} else {
throw new JSONException("illegal ref, " + JSONToken.name(token));
}
lexer.nextToken(JSONToken.RBRACE);
if (lexer.token != JSONToken.RBRACE) {
throw new JSONException("illegal ref");
}
lexer.nextToken(JSONToken.COMMA);
// parser.setContext(context, map, fieldName);
// parser.setContext(context);
return object;
}
if (map.size() == 0 //
&& token == JSONToken.LITERAL_STRING //
&& JSON.DEFAULT_TYPE_KEY.equals(lexer.stringVal()) //
&& !lexer.isEnabled(Feature.DisableSpecialKeyDetect)) {
lexer.nextTokenWithChar(':');
lexer.nextToken(JSONToken.COMMA);
if (lexer.token == JSONToken.RBRACE) {
lexer.nextToken();
return map;
}
lexer.nextToken();
}
Object key = keyDeserializer.deserialze(parser, keyType, null);
if (lexer.token != JSONToken.COLON) {
throw new JSONException("syntax error, expect :, actual " + lexer.token);
}
lexer.nextToken();
Object value = valueDeserializer.deserialze(parser, valueType, key);
if (parser.resolveStatus == DefaultJSONParser.NeedToResolve) {
parser.checkMapResolve(map, key);
}
map.put(key, value);
if (lexer.token == JSONToken.COMMA) {
lexer.nextToken();
}
}
} finally {
parser.setContext(context);
}
return map;
}
@SuppressWarnings({ "unchecked", "rawtypes" })
protected Map, ?> createMap(Type type) {
if (type == Properties.class) {
return new Properties();
}
if (type == Hashtable.class) {
return new Hashtable();
}
if (type == IdentityHashMap.class) {
return new IdentityHashMap();
}
if (type == SortedMap.class || type == TreeMap.class) {
return new TreeMap();
}
if (type == ConcurrentMap.class || type == ConcurrentHashMap.class) {
return new ConcurrentHashMap();
}
if (type == Map.class || type == HashMap.class) {
return new HashMap();
}
if (type == LinkedHashMap.class) {
return new LinkedHashMap();
}
if (type == JSONObject.class) {
return (Map, ?>) new JSONObject();
}
if (type instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) type;
Type rawType = parameterizedType.getRawType();
if (EnumMap.class.equals(rawType)) {
Type[] actualArgs = parameterizedType.getActualTypeArguments();
return new EnumMap((Class) actualArgs[0]);
}
return createMap(rawType);
}
Class> clazz = (Class>) type;
if (clazz.isInterface()) {
throw new JSONException("unsupport type " + type);
}
try {
return (Map, ?>) clazz.newInstance();
} catch (Exception e) {
throw new JSONException("unsupport type " + type, e);
}
}
}