ColumnConverterFactory.java
/*
* Decompiled with CFR 0_132.
*/
package org.xutils.db.converter;
import java.sql.Date;
import java.util.concurrent.ConcurrentHashMap;
import org.xutils.common.util.LogUtil;
import org.xutils.db.converter.BooleanColumnConverter;
import org.xutils.db.converter.ByteArrayColumnConverter;
import org.xutils.db.converter.ByteColumnConverter;
import org.xutils.db.converter.CharColumnConverter;
import org.xutils.db.converter.ColumnConverter;
import org.xutils.db.converter.DateColumnConverter;
import org.xutils.db.converter.DoubleColumnConverter;
import org.xutils.db.converter.FloatColumnConverter;
import org.xutils.db.converter.IntegerColumnConverter;
import org.xutils.db.converter.LongColumnConverter;
import org.xutils.db.converter.ShortColumnConverter;
import org.xutils.db.converter.SqlDateColumnConverter;
import org.xutils.db.converter.StringColumnConverter;
import org.xutils.db.sqlite.ColumnDbType;
public final class ColumnConverterFactory {
private static final ConcurrentHashMap<String, ColumnConverter> columnType_columnConverter_map = new ConcurrentHashMap();
private ColumnConverterFactory() {
}
public static ColumnConverter getColumnConverter(Class columnType) {
ColumnConverter result = null;
if (columnType_columnConverter_map.containsKey(columnType.getName())) {
result = columnType_columnConverter_map.get(columnType.getName());
} else if (ColumnConverter.class.isAssignableFrom(columnType)) {
try {
ColumnConverter columnConverter = (ColumnConverter)columnType.newInstance();
if (columnConverter != null) {
columnType_columnConverter_map.put(columnType.getName(), columnConverter);
}
result = columnConverter;
}
catch (Throwable ex) {
LogUtil.e(ex.getMessage(), ex);
}
}
if (result == null) {
throw new RuntimeException("Database Column Not Support: " + columnType.getName() + ", please impl ColumnConverter or use ColumnConverterFactory#registerColumnConverter(...)");
}
return result;
}
public static ColumnDbType getDbColumnType(Class columnType) {
ColumnConverter converter = ColumnConverterFactory.getColumnConverter(columnType);
return converter.getColumnDbType();
}
public static void registerColumnConverter(Class columnType, ColumnConverter columnConverter) {
columnType_columnConverter_map.put(columnType.getName(), columnConverter);
}
public static boolean isSupportColumnConverter(Class columnType) {
if (columnType_columnConverter_map.containsKey(columnType.getName())) {
return true;
}
if (ColumnConverter.class.isAssignableFrom(columnType)) {
try {
ColumnConverter columnConverter = (ColumnConverter)columnType.newInstance();
if (columnConverter != null) {
columnType_columnConverter_map.put(columnType.getName(), columnConverter);
}
return columnConverter == null;
}
catch (Throwable columnConverter) {
// empty catch block
}
}
return false;
}
static {
BooleanColumnConverter booleanColumnConverter = new BooleanColumnConverter();
columnType_columnConverter_map.put(Boolean.TYPE.getName(), booleanColumnConverter);
columnType_columnConverter_map.put(Boolean.class.getName(), booleanColumnConverter);
ByteArrayColumnConverter byteArrayColumnConverter = new ByteArrayColumnConverter();
columnType_columnConverter_map.put(byte[].class.getName(), byteArrayColumnConverter);
ByteColumnConverter byteColumnConverter = new ByteColumnConverter();
columnType_columnConverter_map.put(Byte.TYPE.getName(), byteColumnConverter);
columnType_columnConverter_map.put(Byte.class.getName(), byteColumnConverter);
CharColumnConverter charColumnConverter = new CharColumnConverter();
columnType_columnConverter_map.put(Character.TYPE.getName(), charColumnConverter);
columnType_columnConverter_map.put(Character.class.getName(), charColumnConverter);
DateColumnConverter dateColumnConverter = new DateColumnConverter();
columnType_columnConverter_map.put(java.util.Date.class.getName(), dateColumnConverter);
DoubleColumnConverter doubleColumnConverter = new DoubleColumnConverter();
columnType_columnConverter_map.put(Double.TYPE.getName(), doubleColumnConverter);
columnType_columnConverter_map.put(Double.class.getName(), doubleColumnConverter);
FloatColumnConverter floatColumnConverter = new FloatColumnConverter();
columnType_columnConverter_map.put(Float.TYPE.getName(), floatColumnConverter);
columnType_columnConverter_map.put(Float.class.getName(), floatColumnConverter);
IntegerColumnConverter integerColumnConverter = new IntegerColumnConverter();
columnType_columnConverter_map.put(Integer.TYPE.getName(), integerColumnConverter);
columnType_columnConverter_map.put(Integer.class.getName(), integerColumnConverter);
LongColumnConverter longColumnConverter = new LongColumnConverter();
columnType_columnConverter_map.put(Long.TYPE.getName(), longColumnConverter);
columnType_columnConverter_map.put(Long.class.getName(), longColumnConverter);
ShortColumnConverter shortColumnConverter = new ShortColumnConverter();
columnType_columnConverter_map.put(Short.TYPE.getName(), shortColumnConverter);
columnType_columnConverter_map.put(Short.class.getName(), shortColumnConverter);
SqlDateColumnConverter sqlDateColumnConverter = new SqlDateColumnConverter();
columnType_columnConverter_map.put(Date.class.getName(), sqlDateColumnConverter);
StringColumnConverter stringColumnConverter = new StringColumnConverter();
columnType_columnConverter_map.put(String.class.getName(), stringColumnConverter);
}
}