On Fri, 18 Aug 2023 21:28:34 GMT, Justin Lu <j...@openjdk.org> wrote:

> Please review this PR and [CSR](https://bugs.openjdk.org/browse/JDK-8314607) 
> which clarifies the behavior of patterns  in regards to the max integer 
> digits in j.text.DecimalFormat.
> 
> The current specification (of `applyPattern`) states that patterns do not set 
> the value of max integer digits. This is incorrect, these 
> methods/constructors do set a value for the max integer digits. If the 
> pattern is in scientific notation, the max integer digits value is derived 
> from the pattern. Otherwise, the pattern is ignored, and the limit is set to 
> `Integer.MAX_VALUE`.
> 
> See below,
> 
> DecimalFormat df = new DecimalFormat();
> df.applyPattern("000.000E0");
> df.getMaximumIntegerDigits(); //  ==> 3
> df.applyPattern("000.000");
> df.getMaximumIntegerDigits(); // ==> 2147483647
> 
> DecimalFormat df = new DecimalFormat("000.000");
> df.getMaximumIntegerDigits(); // ==> 2147483647
> DecimalFormat df = new DecimalFormat("000.000E0");
> df.getMaximumIntegerDigits(); // ==> 3
> 
> 
> Method descriptions should be fixed, and the relevant constructors need to 
> mention the behavior as well.

This pull request has now been integrated.

Changeset: 86a18f5e
Author:    Justin Lu <j...@openjdk.org>
URL:       
https://git.openjdk.org/jdk/commit/86a18f5e2e0825dddb77656b2f43f64684f1464c
Stats:     22 lines in 1 file changed: 13 ins; 2 del; 7 mod

8314604: j.text.DecimalFormat behavior regarding patterns is not clear

Reviewed-by: naoto

-------------

PR: https://git.openjdk.org/jdk/pull/15349

Reply via email to