From 2fa0d49ac4a04b735ca934221127dc80ee4cc6f4 Mon Sep 17 00:00:00 2001 From: Carlos Ruiz Date: Tue, 29 Nov 2022 04:46:40 +0100 Subject: [PATCH] IDEMPIERE-5501 Misses in cache IDisplayTypeFactory (#1592) --- .../src/org/compiere/util/DisplayType.java | 145 +++++++++++------- 1 file changed, 92 insertions(+), 53 deletions(-) diff --git a/org.adempiere.base/src/org/compiere/util/DisplayType.java b/org.adempiere.base/src/org/compiere/util/DisplayType.java index b78557d791..1bddb96e4e 100644 --- a/org.adempiere.base/src/org/compiere/util/DisplayType.java +++ b/org.adempiere.base/src/org/compiere/util/DisplayType.java @@ -232,12 +232,15 @@ public final class DisplayType if (service != null) return service.isID(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isID(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isID(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; @@ -261,12 +264,15 @@ public final class DisplayType if (service != null) return service.isNumeric(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isNumeric(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isNumeric(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; @@ -296,13 +302,16 @@ public final class DisplayType return v != null ? v.intValue() : 0; } } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().getDefaultPrecision(displayType) != null) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - Integer v = found.get().getService().getDefaultPrecision(displayType); - return v != null ? v.intValue() : 0; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + Integer v = found.get().getService().getDefaultPrecision(displayType); + return v != null ? v.intValue() : 0; + } + s_displayTypeFactoryCache.put(displayType, null); } return 0; } // getDefaultPrecision @@ -334,12 +343,15 @@ public final class DisplayType if (service != null) return service.isText(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isText(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isText(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; } // isText @@ -364,12 +376,15 @@ public final class DisplayType if (service != null) return service.isDate(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isDate(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isDate(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; @@ -394,12 +409,15 @@ public final class DisplayType if (service != null) return service.isList(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isList(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isList(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; @@ -427,12 +445,15 @@ public final class DisplayType if (service != null) return service.isLookup(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isLookup(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isLookup(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; @@ -455,12 +476,15 @@ public final class DisplayType if (service != null) return service.isLOB(displayType); } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().isLOB(displayType)) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return true; + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().isLOB(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } return false; @@ -542,12 +566,15 @@ public final class DisplayType return f; } } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().getNumberFormat(displayType, language, pattern) != null) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return found.get().getService().getNumberFormat(displayType, language, pattern); + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().getNumberFormat(displayType, language, pattern); + } + s_displayTypeFactoryCache.put(displayType, null); } format.setMaximumIntegerDigits(MAX_DIGITS); @@ -673,12 +700,15 @@ public final class DisplayType return v; } } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().getDateFormat(displayType, language, pattern) != null) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return found.get().getService().getDateFormat(displayType, language, pattern); + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().getDateFormat(displayType, language, pattern); + } + s_displayTypeFactoryCache.put(displayType, null); } } @@ -760,12 +790,15 @@ public final class DisplayType return v; } } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().getClass(displayType, yesNoAsBoolean) != null) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return found.get().getService().getClass(displayType, yesNoAsBoolean); + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().getClass(displayType, yesNoAsBoolean); + } + s_displayTypeFactoryCache.put(displayType, null); } } // @@ -851,12 +884,15 @@ public final class DisplayType return v; } } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().getSQLDataType(displayType, columnName, fieldLength) != null) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return found.get().getService().getSQLDataType(displayType, columnName, fieldLength); + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().getSQLDataType(displayType, columnName, fieldLength); + } + s_displayTypeFactoryCache.put(displayType, null); } if (!DisplayType.isText(displayType)) @@ -955,12 +991,15 @@ public final class DisplayType return v; } } - Optional> found = getDisplayTypeFactories().stream() + if (! s_displayTypeFactoryCache.containsKey(displayType)) { + Optional> found = getDisplayTypeFactories().stream() .filter(e -> e.getService() != null && e.getService().getDescription(displayType) != null) .findFirst(); - if (found.isPresent()) { - s_displayTypeFactoryCache.put(displayType, found.get()); - return found.get().getService().getDescription(displayType); + if (found.isPresent()) { + s_displayTypeFactoryCache.put(displayType, found.get()); + return found.get().getService().getDescription(displayType); + } + s_displayTypeFactoryCache.put(displayType, null); } //