diff --git a/poi/src/main/java/org/apache/poi/ss/formula/functions/NumericFunction.java b/poi/src/main/java/org/apache/poi/ss/formula/functions/NumericFunction.java index bc0ccfe4820..a0baba1e139 100644 --- a/poi/src/main/java/org/apache/poi/ss/formula/functions/NumericFunction.java +++ b/poi/src/main/java/org/apache/poi/ss/formula/functions/NumericFunction.java @@ -106,7 +106,11 @@ private static ValueEval evaluateDollar(ValueEval[] args, int srcRowIndex, int s DecimalFormat nf = (DecimalFormat) NumberFormat.getCurrencyInstance(LocaleUtil.getUserLocale()); int decimalPlaces = Math.max(nPlaces, 0); if (LocaleUtil.getUserLocale().getCountry().equalsIgnoreCase("US")) { - nf.setNegativePrefix("(" + nf.getDecimalFormatSymbols().getCurrencySymbol()); + // Java 23 removed "COMPAT" locale provider and thus + // we need to ensure that the dollar-sign is used and not "USD" as Java 23 and newer + // would do + nf.setPositivePrefix("$"); + nf.setNegativePrefix("($"); nf.setNegativeSuffix(")"); } nf.setMinimumFractionDigits(decimalPlaces); diff --git a/poi/src/test/java/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java b/poi/src/test/java/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java index 0588c75a774..b3ccd06a4c4 100644 --- a/poi/src/test/java/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java +++ b/poi/src/test/java/org/apache/poi/ss/usermodel/TestExcelStyleDateFormatter.java @@ -73,10 +73,26 @@ void test60369(Locale locale, String expected, Date d, int month) { * is expected and selected via an index */ private static int localeIndex(Locale locale) { - return jreVersion < 9 || - !locale.equals (Locale.CHINESE) || - (provider != null && (provider.startsWith("JRE") || provider.startsWith("COMPAT"))) - ? 0 : 1; + if (jreVersion < 9) { + return 0; + } + + // only Chinese needs special handling + if (!locale.equals (Locale.CHINESE)) { + return 0; + } + + // in JDK 23, the COMPAT/JRE provider was removed completely + if (jreVersion >= 23) { + return 1; + } + + // check if the JRE/COMPAT locale provide is selected + if (provider != null && (provider.startsWith("JRE") || provider.startsWith("COMPAT"))) { + return 0; + } + + return 1; } /**