Failure to generate getI* shouldn't be fatal. Also, the current algorithm use to discover the reference tablename is by no mean fool proof.
This commit is contained in:
parent
6b33b0ab59
commit
4022504df5
|
@ -397,48 +397,49 @@ public class ModelClassGenerator
|
||||||
String referenceClassName = "I_"+columnName.substring(0, columnName.length()-3);
|
String referenceClassName = "I_"+columnName.substring(0, columnName.length()-3);
|
||||||
|
|
||||||
MTable table = MTable.get(Env.getCtx(), tableName);
|
MTable table = MTable.get(Env.getCtx(), tableName);
|
||||||
if (table == null)
|
if (table != null)
|
||||||
throw new RuntimeException("No table found for "+tableName);
|
{
|
||||||
String entityType = table.getEntityType();
|
String entityType = table.getEntityType();
|
||||||
if (!"D".equals(entityType))
|
if (!"D".equals(entityType))
|
||||||
{
|
{
|
||||||
for (int i = 0; i < entityTypes.length; i++)
|
for (int i = 0; i < entityTypes.length; i++)
|
||||||
{
|
|
||||||
if (entityTypes[i].getEntityType().equals(entityType))
|
|
||||||
{
|
{
|
||||||
String modelpackage = entityTypes[i].getModelPackage();
|
if (entityTypes[i].getEntityType().equals(entityType))
|
||||||
if (modelpackage != null)
|
{
|
||||||
{
|
String modelpackage = entityTypes[i].getModelPackage();
|
||||||
referenceClassName = modelpackage+".I_"+columnName.substring(0, columnName.length()-3);
|
if (modelpackage != null)
|
||||||
break;
|
{
|
||||||
|
referenceClassName = modelpackage+".I_"+columnName.substring(0, columnName.length()-3);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
//end [ 1785001 ]
|
||||||
//end [ 1785001 ]
|
sb.append(NL)
|
||||||
sb.append(NL)
|
.append("\tpublic "+referenceClassName+" get").append(tableName).append("() throws RuntimeException ").append(NL)
|
||||||
.append("\tpublic "+referenceClassName+" get").append(tableName).append("() throws RuntimeException ").append(NL)
|
.append(" {").append(NL)
|
||||||
.append(" {").append(NL)
|
// TODO - here we can implement Lazy loading or Cache of class
|
||||||
// TODO - here we can implement Lazy loading or Cache of class
|
.append(" Class<?> clazz = MTable.getClass("+referenceClassName+".Table_Name);").append(NL)
|
||||||
.append(" Class<?> clazz = MTable.getClass("+referenceClassName+".Table_Name);").append(NL)
|
.append(" ").append(referenceClassName).append(" result = null;").append(NL)
|
||||||
.append(" ").append(referenceClassName).append(" result = null;").append(NL)
|
.append(" try {").append(NL)
|
||||||
.append(" try {").append(NL)
|
.append(" Constructor<?> constructor = null;").append(NL)
|
||||||
.append(" Constructor<?> constructor = null;").append(NL)
|
// .append(" try {").append(NL)
|
||||||
// .append(" try {").append(NL)
|
.append(" constructor = clazz.getDeclaredConstructor(new Class[]{Properties.class, int.class, String.class});").append(NL)
|
||||||
.append(" constructor = clazz.getDeclaredConstructor(new Class[]{Properties.class, int.class, String.class});").append(NL)
|
// .append(" } catch (NoSuchMethodException e) {").append(NL)
|
||||||
// .append(" } catch (NoSuchMethodException e) {").append(NL)
|
// .append(" log.warning(\"No transaction Constructor for \" + clazz + \" Exception[\" + e.toString() + \"]\");").append(NL)
|
||||||
// .append(" log.warning(\"No transaction Constructor for \" + clazz + \" Exception[\" + e.toString() + \"]\");").append(NL)
|
// .append(" }").append(NL)
|
||||||
// .append(" }").append(NL)
|
// TODO - here we can implement Lazy loading or Cache of record. Like in Hibernate, objects can be loaded on demand or when master object is loaded.
|
||||||
// TODO - here we can implement Lazy loading or Cache of record. Like in Hibernate, objects can be loaded on demand or when master object is loaded.
|
.append(" result = ("+referenceClassName+")constructor.newInstance(new Object[] {getCtx(), new Integer(get"+columnName+"()), get_TrxName()});").append(NL)
|
||||||
.append(" result = ("+referenceClassName+")constructor.newInstance(new Object[] {getCtx(), new Integer(get"+columnName+"()), get_TrxName()});").append(NL)
|
.append(" } catch (Exception e) {").append(NL)
|
||||||
.append(" } catch (Exception e) {").append(NL)
|
.append(" log.log(Level.SEVERE, \"(id) - Table=\" + Table_Name + \",Class=\" + clazz, e);").append(NL)
|
||||||
.append(" log.log(Level.SEVERE, \"(id) - Table=\" + Table_Name + \",Class=\" + clazz, e);").append(NL)
|
.append(" log.saveError(\"Error\", \"Table=\" + Table_Name + \",Class=\" + clazz);").append(NL)
|
||||||
.append(" log.saveError(\"Error\", \"Table=\" + Table_Name + \",Class=\" + clazz);").append(NL)
|
.append(" throw new RuntimeException( e );").append(NL)
|
||||||
.append(" throw new RuntimeException( e );").append(NL)
|
.append(" }").append(NL)
|
||||||
.append(" }").append(NL)
|
.append(" return result;").append(NL)
|
||||||
.append(" return result;").append(NL)
|
.append(" }").append(NL)
|
||||||
.append(" }").append(NL)
|
;
|
||||||
;
|
}
|
||||||
// Add imports:
|
// Add imports:
|
||||||
addImportClass(java.lang.reflect.Constructor.class);
|
addImportClass(java.lang.reflect.Constructor.class);
|
||||||
addImportClass(java.util.logging.Level.class);
|
addImportClass(java.util.logging.Level.class);
|
||||||
|
|
|
@ -360,27 +360,29 @@ public class ModelInterfaceGenerator
|
||||||
String tableName = columnName.substring(0, columnName.length()-3);
|
String tableName = columnName.substring(0, columnName.length()-3);
|
||||||
|
|
||||||
MTable table = MTable.get(Env.getCtx(), tableName);
|
MTable table = MTable.get(Env.getCtx(), tableName);
|
||||||
String entityType = table.getEntityType();
|
if (table != null) {
|
||||||
if (!"D".equals(entityType))
|
String entityType = table.getEntityType();
|
||||||
{
|
if (!"D".equals(entityType))
|
||||||
for (int i = 0; i < entityTypes.length; i++)
|
{
|
||||||
{
|
for (int i = 0; i < entityTypes.length; i++)
|
||||||
if (entityTypes[i].getEntityType().equals(entityType))
|
|
||||||
{
|
{
|
||||||
String modelpackage = entityTypes[i].getModelPackage();
|
if (entityTypes[i].getEntityType().equals(entityType))
|
||||||
if (modelpackage != null)
|
{
|
||||||
{
|
String modelpackage = entityTypes[i].getModelPackage();
|
||||||
referenceClassName = modelpackage+".I_"+columnName.substring(0, columnName.length()-3);
|
if (modelpackage != null)
|
||||||
break;
|
{
|
||||||
|
referenceClassName = modelpackage+".I_"+columnName.substring(0, columnName.length()-3);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
//end [ 1785001 ]
|
||||||
//end [ 1785001 ]
|
|
||||||
|
sb.append("\n")
|
||||||
sb.append("\n")
|
.append("\tpublic "+referenceClassName+" get").append(tableName).append("() throws RuntimeException;")
|
||||||
.append("\tpublic "+referenceClassName+" get").append(tableName).append("() throws RuntimeException;")
|
;
|
||||||
;
|
}
|
||||||
} else {
|
} else {
|
||||||
// TODO - Handle other types
|
// TODO - Handle other types
|
||||||
//sb.append("\tpublic I_"+columnName+" getI_").append(columnName).append("(){return null; };");
|
//sb.append("\tpublic I_"+columnName+" getI_").append(columnName).append("(){return null; };");
|
||||||
|
|
Loading…
Reference in New Issue