ChestShop-3/com/Acrobot/Breeze/Database/EntityParser.java

74 lines
1.9 KiB
Java
Raw Normal View History

2012-10-28 23:53:26 +01:00
package com.Acrobot.Breeze.Database;
import com.google.common.base.Joiner;
import javax.persistence.Entity;
import javax.persistence.Id;
2012-10-28 23:53:26 +01:00
import java.lang.annotation.AnnotationFormatError;
import java.lang.reflect.Field;
import java.util.LinkedList;
import java.util.List;
/**
* Parses an entity (class with database fields)
*
* @author Acrobot
*/
public class EntityParser {
private Class entity;
public EntityParser(Class table) {
if (!table.isAnnotationPresent(Entity.class) || !table.isAnnotationPresent(javax.persistence.Table.class)) {
throw new AnnotationFormatError("The class hasn't got Entity or Table annotation!");
}
entity = table;
}
/**
* Parses the class' fields to a standard SQL format
*
* @return SQLed class
*/
public String parseToString() {
List<String> fields = new LinkedList<String>();
for (Field field : entity.getDeclaredFields()) {
fields.add(convertToSQL(field));
}
return Joiner.on(',').join(fields);
}
/**
* Converts a field type to SQL type
*
* @param field Java's field
* @return SQL type
*/
public String convertToSQL(Field field) {
String sqlType = "";
Class<?> type = field.getType();
if (type.isAssignableFrom(String.class)) {
sqlType += "VARCHAR(255)";
} else if (type.isAssignableFrom(boolean.class)) {
sqlType += "BOOLEAN";
} else if (type.isAssignableFrom(int.class)) {
sqlType += "INTEGER";
} else if (type.isAssignableFrom(double.class)) {
sqlType += "DOUBLE";
} else if (type.isAssignableFrom(float.class)) {
sqlType += "FLOAT";
} else {
sqlType += "TEXT";
}
if (field.isAnnotationPresent(Id.class)) {
sqlType += " AUTO INCREMENT";
}
2012-10-28 23:54:06 +01:00
return null; //TODO Finish this
2012-10-28 23:53:26 +01:00
}
}