IDEMPIERE-2278 Entity Types are not cached - but static array
This commit is contained in:
parent
05300e6a54
commit
3dbec5eb0f
|
@ -616,13 +616,9 @@ public class ModelInterfaceGenerator
|
||||||
if ("D".equals(entityType))
|
if ("D".equals(entityType))
|
||||||
return "org.compiere.model";
|
return "org.compiere.model";
|
||||||
|
|
||||||
for (MEntityType entity : MEntityType.getEntityTypes(Env.getCtx()))
|
MEntityType entity = MEntityType.get(Env.getCtx(), entityType);
|
||||||
{
|
if (entity != null)
|
||||||
if (entity.getEntityType().equals(entityType))
|
|
||||||
{
|
|
||||||
return entity.getModelPackage();
|
return entity.getModelPackage();
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,15 +16,13 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
package org.compiere.model;
|
package org.compiere.model;
|
||||||
|
|
||||||
|
import static org.compiere.model.SystemIDs.ENTITYTYPE_ADEMPIERE;
|
||||||
|
import static org.compiere.model.SystemIDs.ENTITYTYPE_DICTIONARY;
|
||||||
|
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.StringTokenizer;
|
|
||||||
import java.util.logging.Level;
|
|
||||||
|
|
||||||
import static org.compiere.model.SystemIDs.*;
|
|
||||||
|
|
||||||
|
import org.compiere.util.CCache;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.util.CLogger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -46,26 +44,7 @@ public class MEntityType extends X_AD_EntityType
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private static final long serialVersionUID = 4670009709141738924L;
|
private static final long serialVersionUID = -8449015496292546851L;
|
||||||
|
|
||||||
/**
|
|
||||||
* Get Entity Types
|
|
||||||
* @param ctx context
|
|
||||||
* @return entity type array
|
|
||||||
*/
|
|
||||||
static synchronized public MEntityType[] getEntityTypes(Properties ctx)
|
|
||||||
{
|
|
||||||
if (s_entityTypes != null)
|
|
||||||
return s_entityTypes;
|
|
||||||
List<MEntityType> list = new Query(ctx, Table_Name, null, null)
|
|
||||||
.setOnlyActiveRecords(true)
|
|
||||||
.setOrderBy(COLUMNNAME_AD_EntityType_ID)
|
|
||||||
.list();
|
|
||||||
s_entityTypes = new MEntityType[list.size()];
|
|
||||||
list.toArray(s_entityTypes);
|
|
||||||
if (s_log.isLoggable(Level.FINER)) s_log.finer("# " + s_entityTypes.length);
|
|
||||||
return s_entityTypes;
|
|
||||||
} // getEntityTypes
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get EntityType object by name
|
* Get EntityType object by name
|
||||||
|
@ -75,102 +54,21 @@ public class MEntityType extends X_AD_EntityType
|
||||||
*/
|
*/
|
||||||
public static MEntityType get(Properties ctx, String entityType)
|
public static MEntityType get(Properties ctx, String entityType)
|
||||||
{
|
{
|
||||||
for (MEntityType entity : getEntityTypes(ctx))
|
MEntityType retValue = (MEntityType) s_cache.get (entityType);
|
||||||
{
|
if (retValue != null)
|
||||||
if (entity.getEntityType().equals(entityType))
|
|
||||||
{
|
|
||||||
return entity;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get Entity Type as String array
|
|
||||||
* @param ctx context
|
|
||||||
* @return entity type array
|
|
||||||
*/
|
|
||||||
static public String[] getEntityTypeStrings(Properties ctx)
|
|
||||||
{
|
|
||||||
MEntityType[] entityTypes = getEntityTypes(ctx);
|
|
||||||
ArrayList<String> list = new ArrayList<String>(); // list capabilities
|
|
||||||
String[] retValue = new String[entityTypes.length];
|
|
||||||
for (int i = 0; i < entityTypes.length; i++)
|
|
||||||
{
|
|
||||||
String s = entityTypes[i].getEntityType().trim();
|
|
||||||
list.add(s);
|
|
||||||
retValue[i] = s;
|
|
||||||
}
|
|
||||||
if (s_log.isLoggable(Level.FINER)) s_log.finer(list.toString());
|
|
||||||
return retValue;
|
return retValue;
|
||||||
} // getEntityTypeStrings
|
retValue = new Query(ctx, Table_Name, "EntityType=?", null)
|
||||||
|
.setParameters(entityType)
|
||||||
/**
|
.firstOnly();
|
||||||
* Get Entity Type Classpath array
|
if (retValue != null)
|
||||||
* @param ctx context
|
s_cache.put (entityType, retValue);
|
||||||
* @return classpath array
|
|
||||||
*/
|
|
||||||
static public String[] getClasspaths(Properties ctx)
|
|
||||||
{
|
|
||||||
MEntityType[] entityTypes = getEntityTypes(ctx);
|
|
||||||
ArrayList<String> list = new ArrayList<String>();
|
|
||||||
for (int i = 0; i < entityTypes.length; i++)
|
|
||||||
{
|
|
||||||
String classpath = entityTypes[i].getClasspath();
|
|
||||||
if (classpath == null || classpath.length() == 0)
|
|
||||||
continue;
|
|
||||||
StringTokenizer st = new StringTokenizer(classpath, ";, \t\n\r\f");
|
|
||||||
while (st.hasMoreTokens())
|
|
||||||
{
|
|
||||||
String token = st.nextToken();
|
|
||||||
if (token.length() > 0)
|
|
||||||
{
|
|
||||||
if (!list.contains(token))
|
|
||||||
list.add(token);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
String[] retValue = new String[list.size()];
|
|
||||||
list.toArray(retValue);
|
|
||||||
if (s_log.isLoggable(Level.FINER)) s_log.finer(list.toString());
|
|
||||||
return retValue;
|
return retValue;
|
||||||
} // getClathpaths
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get Entity Type Model Package array
|
|
||||||
* @param ctx context
|
|
||||||
* @return entity type array
|
|
||||||
*/
|
|
||||||
static public String[] getModelPackages(Properties ctx)
|
|
||||||
{
|
|
||||||
MEntityType[] entityTypes = getEntityTypes(ctx);
|
|
||||||
ArrayList<String> list = new ArrayList<String>();
|
|
||||||
list.add("adempiere.model"); // default
|
|
||||||
for (int i = 0; i < entityTypes.length; i++)
|
|
||||||
{
|
|
||||||
String modelPackage = entityTypes[i].getModelPackage();
|
|
||||||
if (modelPackage == null || modelPackage.length() == 0)
|
|
||||||
continue;
|
|
||||||
StringTokenizer st = new StringTokenizer(modelPackage, ";, \t\n\r\f");
|
|
||||||
while (st.hasMoreTokens())
|
|
||||||
{
|
|
||||||
String token = st.nextToken();
|
|
||||||
if (token.length() > 0)
|
|
||||||
{
|
|
||||||
if (!list.contains(token))
|
|
||||||
list.add(token);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
String[] retValue = new String[list.size()];
|
|
||||||
list.toArray(retValue);
|
|
||||||
if (s_log.isLoggable(Level.FINER)) s_log.finer(list.toString());
|
|
||||||
return retValue;
|
|
||||||
} // getModelPackages
|
|
||||||
|
|
||||||
/** Cached EntityTypes */
|
/** Cached EntityTypes */
|
||||||
private static MEntityType[] s_entityTypes = null;
|
private static CCache<String,MEntityType> s_cache = new CCache<String,MEntityType>(Table_Name, 20);
|
||||||
/** Logger */
|
/** Logger */
|
||||||
|
@SuppressWarnings("unused")
|
||||||
private static CLogger s_log = CLogger.getCLogger (MEntityType.class);
|
private static CLogger s_log = CLogger.getCLogger (MEntityType.class);
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
|
@ -268,7 +166,6 @@ public class MEntityType extends X_AD_EntityType
|
||||||
*/
|
*/
|
||||||
//setAD_EntityType_ID();
|
//setAD_EntityType_ID();
|
||||||
} // new
|
} // new
|
||||||
s_entityTypes = null; // reset
|
|
||||||
return true;
|
return true;
|
||||||
} // beforeSave
|
} // beforeSave
|
||||||
|
|
||||||
|
@ -283,7 +180,6 @@ public class MEntityType extends X_AD_EntityType
|
||||||
log.saveError("Error", "You cannot delete a System maintained entity");
|
log.saveError("Error", "You cannot delete a System maintained entity");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
s_entityTypes = null; // reset
|
|
||||||
return true;
|
return true;
|
||||||
} // beforeDelete
|
} // beforeDelete
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue