From 0147b47f31f855a77724a926a4545ac1a2dc6fe1 Mon Sep 17 00:00:00 2001 From: Carlos Ruiz Date: Tue, 3 Mar 2020 15:04:10 +0100 Subject: [PATCH] IDEMPIERE-308 Performance: Replace use of StringBuffer and String concatenation with StringBuilder / Add a helper getName by default in the toString method in X_ class --- .../org/adempiere/util/ModelClassGenerator.java | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/org.adempiere.base/src/org/adempiere/util/ModelClassGenerator.java b/org.adempiere.base/src/org/adempiere/util/ModelClassGenerator.java index 5b6acf501b..0da54de921 100644 --- a/org.adempiere.base/src/org/adempiere/util/ModelClassGenerator.java +++ b/org.adempiere.base/src/org/adempiere/util/ModelClassGenerator.java @@ -238,15 +238,21 @@ public class ModelClassGenerator .append(" {").append(NL) .append(" POInfo poi = POInfo.getPOInfo (ctx, Table_ID, get_TrxName());").append(NL) .append(" return poi;").append(NL) - .append(" }").append(NL) + .append(" }").append(NL); // initPO + final String sqlCol = "SELECT COUNT(*) FROM AD_Column WHERE AD_Table_ID=? AND ColumnName=? AND IsActive='Y'"; + boolean hasName = (DB.getSQLValue(null, sqlCol, AD_Table_ID, "Name") == 1); // toString() - .append(NL) + start.append(NL) .append(" public String toString()").append(NL) .append(" {").append(NL) - .append(" StringBuffer sb = new StringBuffer (\"").append(className).append("[\")").append(NL) - .append(" .append(get_ID()).append(\"]\");").append(NL) + .append(" StringBuilder sb = new StringBuilder (\"").append(className).append("[\")").append(NL) + // TODO: generate getName if there is a Name column -- .append(",Name=").append(getName()) + .append(" .append(get_ID())"); + if (hasName) + start.append(".append(\",Name=\").append(getName())"); + start.append(".append(\"]\");").append(NL) .append(" return sb.toString();").append(NL) .append(" }").append(NL) ;