test/java/util/Formatter/BasicDouble.java
Print this page
rev 10699 : 8058887: (fmt) Improve java/util/Formatter test coverage of group separators and width
*** 1,7 ****
/*
! * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
--- 1,7 ----
/*
! * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*** 34,62 ****
import java.math.BigDecimal;
import java.math.BigInteger;
import java.text.DateFormatSymbols;
import java.util.*;
! import static java.util.Calendar.*;
!
!
!
public class BasicDouble extends Basic {
private static void test(String fs, String exp, Object ... args) {
Formatter f = new Formatter(new StringBuilder(), Locale.US);
f.format(fs, args);
ck(fs, exp, f.toString());
}
private static void test(Locale l, String fs, String exp, Object ... args)
{
Formatter f = new Formatter(new StringBuilder(), l);
f.format(fs, args);
ck(fs, exp, f.toString());
}
private static void test(String fs, Object ... args) {
Formatter f = new Formatter(new StringBuilder(), Locale.US);
f.format(fs, args);
--- 34,68 ----
import java.math.BigDecimal;
import java.math.BigInteger;
import java.text.DateFormatSymbols;
import java.util.*;
! import sun.misc.DoubleConsts;
+ import static java.util.Calendar.*;
public class BasicDouble extends Basic {
private static void test(String fs, String exp, Object ... args) {
Formatter f = new Formatter(new StringBuilder(), Locale.US);
f.format(fs, args);
ck(fs, exp, f.toString());
+
+ f = new Formatter(new StringBuilder(), Locale.US);
+ f.format("foo " + fs + " bar", args);
+ ck(fs, "foo " + exp + " bar", f.toString());
}
private static void test(Locale l, String fs, String exp, Object ... args)
{
Formatter f = new Formatter(new StringBuilder(), l);
f.format(fs, args);
ck(fs, exp, f.toString());
+
+ f = new Formatter(new StringBuilder(), l);
+ f.format("foo " + fs + " bar", args);
+ ck(fs, "foo " + exp + " bar", f.toString());
}
private static void test(String fs, Object ... args) {
Formatter f = new Formatter(new StringBuilder(), Locale.US);
f.format(fs, args);
*** 130,304 ****
fail(fs, ex);
else
pass();
}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
private static double create(double v) {
return (double) v;
}
-
private static double negate(double v) {
return -v;
}
private static double mult(double v, double mul) {
--- 136,149 ----
*** 307,334 ****
private static double recip(double v) {
return 1.0 / v;
}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
public static void test() {
TimeZone.setDefault(TimeZone.getTimeZone("GMT-0800"));
// Any characters not explicitly defined as conversions, date/time
// conversion suffixes, or flags are illegal and are reserved for
--- 152,161 ----
*** 510,1555 ****
//---------------------------------------------------------------------
tryCatch("%F", UnknownFormatConversionException.class);
tryCatch("%#g", FormatFlagsConversionMismatchException.class);
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
! //---------------------------------------------------------------------
! // %s - double
! //---------------------------------------------------------------------
! double one = 1.0;
! double ten = 10.0;
! double pi = Math.PI;
!
! test("%s", "3.141592653589793", pi);
!
!
!
!
!
!
!
!
!
!
!
!
! //---------------------------------------------------------------------
! // flag/conversion errors
! //---------------------------------------------------------------------
! tryCatch("%d", IllegalFormatConversionException.class, one);
! tryCatch("%,.4e", FormatFlagsConversionMismatchException.class, one);
!
! //---------------------------------------------------------------------
! // %e
! //
! // Floating-point conversions applicable to float, double, and
! // BigDecimal.
! //---------------------------------------------------------------------
! test("%e", "null", (Object)null);
!
! //---------------------------------------------------------------------
! // %e - float and double
! //---------------------------------------------------------------------
! // double PI = 3.141 592 653 589 793 238 46;
! test("%e", "3.141593e+00", pi);
! test("%.0e", "1e+01", ten);
! test("%#.0e", "1.e+01", ten);
! test("%E", "3.141593E+00", pi);
! test("%10.3e", " 3.142e+00", pi);
! test("%10.3e", "-3.142e+00", negate(pi));
! test("%010.3e", "03.142e+00", pi);
! test("%010.3e", "-3.142e+00", negate(pi));
! test("%-12.3e", "3.142e+00 ", pi);
! test("%-12.3e", "-3.142e+00 ", negate(pi));
! test("%.3e", "3.142e+00", pi);
! test("%.3e", "-3.142e+00", negate(pi));
! test("%.3e", "3.142e+06", mult(pi, 1000000.0));
! test("%.3e", "-3.142e+06", mult(pi, -1000000.0));
!
! test(Locale.FRANCE, "%e", "3,141593e+00", pi);
!
! // double PI^300
! // = 13962455701329742638131355433930076081862072808 ... e+149
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
! test("%10.3e", " 1.000e+00", one);
! test("%+.3e", "+3.142e+00", pi);
! test("%+.3e", "-3.142e+00", negate(pi));
! test("% .3e", " 3.142e+00", pi);
! test("% .3e", "-3.142e+00", negate(pi));
! test("%#.0e", "3.e+00", create(3.0));
! test("%#.0e", "-3.e+00", create(-3.0));
! test("%.0e", "3e+00", create(3.0));
! test("%.0e", "-3e+00", create(-3.0));
!
! test("%(.4e", "3.1416e+06", mult(pi, 1000000.0));
! test("%(.4e", "(3.1416e+06)", mult(pi, -1000000.0));
!
! //---------------------------------------------------------------------
! // %e - boundary problems
! //---------------------------------------------------------------------
! test("%3.0e", "1e-06", 0.000001);
! test("%3.0e", "1e-05", 0.00001);
! test("%3.0e", "1e-04", 0.0001);
! test("%3.0e", "1e-03", 0.001);
! test("%3.0e", "1e-02", 0.01);
! test("%3.0e", "1e-01", 0.1);
! test("%3.0e", "9e-01", 0.9);
! test("%3.1e", "9.0e-01", 0.9);
! test("%3.0e", "1e+00", 1.00);
! test("%3.0e", "1e+01", 10.00);
! test("%3.0e", "1e+02", 99.19);
! test("%3.1e", "9.9e+01", 99.19);
! test("%3.0e", "1e+02", 99.99);
! test("%3.0e", "1e+02", 100.00);
! test("%#3.0e", "1.e+03", 1000.00);
! test("%3.0e", "1e+04", 10000.00);
! test("%3.0e", "1e+05", 100000.00);
! test("%3.0e", "1e+06", 1000000.00);
! test("%3.0e", "1e+07", 10000000.00);
! test("%3.0e", "1e+08", 100000000.00);
!
! //---------------------------------------------------------------------
! // %f
! //
! // Floating-point conversions applicable to float, double, and
! // BigDecimal.
! //---------------------------------------------------------------------
! test("%f", "null", (Object)null);
! test("%f", "3.141593", pi);
! test(Locale.FRANCE, "%f", "3,141593", pi);
! test("%10.3f", " 3.142", pi);
! test("%10.3f", " -3.142", negate(pi));
! test("%010.3f", "000003.142", pi);
! test("%010.3f", "-00003.142", negate(pi));
! test("%-10.3f", "3.142 ", pi);
! test("%-10.3f", "-3.142 ", negate(pi));
! test("%.3f", "3.142", pi);
! test("%.3f", "-3.142", negate(pi));
! test("%+.3f", "+3.142", pi);
! test("%+.3f", "-3.142", negate(pi));
! test("% .3f", " 3.142", pi);
! test("% .3f", "-3.142", negate(pi));
! test("%#.0f", "3.", create(3.0));
! test("%#.0f", "-3.", create(-3.0));
! test("%.0f", "3", create(3.0));
! test("%.0f", "-3", create(-3.0));
! test("%.3f", "10.000", ten);
! test("%.3f", "1.000", one);
! test("%10.3f", " 1.000", one);
!
! //---------------------------------------------------------------------
! // %f - boundary problems
! //---------------------------------------------------------------------
! test("%3.0f", " 0", 0.000001);
! test("%3.0f", " 0", 0.00001);
! test("%3.0f", " 0", 0.0001);
! test("%3.0f", " 0", 0.001);
! test("%3.0f", " 0", 0.01);
! test("%3.0f", " 0", 0.1);
! test("%3.0f", " 1", 0.9);
! test("%3.1f", "0.9", 0.9);
! test("%3.0f", " 1", 1.00);
! test("%3.0f", " 10", 10.00);
! test("%3.0f", " 99", 99.19);
! test("%3.1f", "99.2", 99.19);
! test("%3.0f", "100", 99.99);
! test("%3.0f", "100", 100.00);
! test("%#3.0f", "1000.", 1000.00);
! test("%3.0f", "10000", 10000.00);
! test("%3.0f", "100000", 100000.00);
! test("%3.0f", "1000000", 1000000.00);
! test("%3.0f", "10000000", 10000000.00);
! test("%3.0f", "100000000", 100000000.00);
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
//---------------------------------------------------------------------
! // %f - float, double, Double, BigDecimal
//---------------------------------------------------------------------
! test("%.3f", "3141592.654", mult(pi, 1000000.0));
! test("%.3f", "-3141592.654", mult(pi, -1000000.0));
! test("%,.4f", "3,141,592.6536", mult(pi, 1000000.0));
! test(Locale.FRANCE, "%,.4f", "3\u00a0141\u00a0592,6536", mult(pi, 1000000.0));
! test("%,.4f", "-3,141,592.6536", mult(pi, -1000000.0));
! test("%(.4f", "3141592.6536", mult(pi, 1000000.0));
! test("%(.4f", "(3141592.6536)", mult(pi, -1000000.0));
! test("%(,.4f", "3,141,592.6536", mult(pi, 1000000.0));
! test("%(,.4f", "(3,141,592.6536)", mult(pi, -1000000.0));
!
!
!
//---------------------------------------------------------------------
! // %g
//
// Floating-point conversions applicable to float, double, and
// BigDecimal.
//---------------------------------------------------------------------
! test("%g", "null", (Object)null);
! test("%g", "3.14159", pi);
! test(Locale.FRANCE, "%g", "3,14159", pi);
! test("%.0g", "1e+01", ten);
! test("%G", "3.14159", pi);
! test("%10.3g", " 3.14", pi);
! test("%10.3g", " -3.14", negate(pi));
! test("%010.3g", "0000003.14", pi);
! test("%010.3g", "-000003.14", negate(pi));
! test("%-12.3g", "3.14 ", pi);
! test("%-12.3g", "-3.14 ", negate(pi));
! test("%.3g", "3.14", pi);
! test("%.3g", "-3.14", negate(pi));
! test("%.3g", "3.14e+08", mult(pi, 100000000.0));
! test("%.3g", "-3.14e+08", mult(pi, -100000000.0));
!
! test("%.3g", "1.00e-05", recip(create(100000.0)));
! test("%.3g", "-1.00e-05", recip(create(-100000.0)));
! test("%.0g", "-1e-05", recip(create(-100000.0)));
! test("%.0g", "1e+05", create(100000.0));
! test("%.3G", "1.00E-05", recip(create(100000.0)));
! test("%.3G", "-1.00E-05", recip(create(-100000.0)));
!
! test("%.1g", "-0", -0.0);
! test("%3.0g", " -0", -0.0);
! test("%.1g", "0", 0.0);
! test("%3.0g", " 0", 0.0);
! test("%.1g", "0", +0.0);
! test("%3.0g", " 0", +0.0);
!
! test("%3.0g", "1e-06", 0.000001);
! test("%3.0g", "1e-05", 0.00001);
! test("%3.0g", "1e-05", 0.0000099);
! test("%3.1g", "1e-05", 0.0000099);
! test("%3.2g", "9.9e-06", 0.0000099);
! test("%3.0g", "0.0001", 0.0001);
! test("%3.0g", "9e-05", 0.00009);
! test("%3.0g", "0.0001", 0.000099);
! test("%3.1g", "0.0001", 0.000099);
! test("%3.2g", "9.9e-05", 0.000099);
! test("%3.0g", "0.001", 0.001);
! test("%3.0g", "0.001", 0.00099);
! test("%3.1g", "0.001", 0.00099);
! test("%3.2g", "0.00099", 0.00099);
! test("%3.3g", "0.00100", 0.001);
! test("%3.4g", "0.001000", 0.001);
! test("%3.0g", "0.01", 0.01);
! test("%3.0g", "0.1", 0.1);
! test("%3.0g", "0.9", 0.9);
! test("%3.1g", "0.9", 0.9);
! test("%3.0g", " 1", 1.00);
! test("%3.2g", " 10", 10.00);
! test("%3.0g", "1e+01", 10.00);
! test("%3.0g", "1e+02", 99.19);
! test("%3.1g", "1e+02", 99.19);
! test("%3.2g", " 99", 99.19);
! test("%3.0g", "1e+02", 99.9);
! test("%3.1g", "1e+02", 99.9);
! test("%3.2g", "1.0e+02", 99.9);
! test("%3.0g", "1e+02", 99.99);
! test("%3.0g", "1e+02", 100.00);
! test("%3.0g", "1e+03", 999.9);
! test("%3.1g", "1e+03", 999.9);
! test("%3.2g", "1.0e+03", 999.9);
! test("%3.3g", "1.00e+03", 999.9);
! test("%3.4g", "999.9", 999.9);
! test("%3.4g", "1000", 999.99);
! test("%3.0g", "1e+03", 1000.00);
! test("%3.0g", "1e+04", 10000.00);
! test("%3.0g", "1e+05", 100000.00);
! test("%3.0g", "1e+06", 1000000.00);
! test("%3.0g", "1e+07", 10000000.00);
! test("%3.9g", "100000000", 100000000.00);
! test("%3.10g", "100000000.0", 100000000.00);
!
! tryCatch("%#3.0g", FormatFlagsConversionMismatchException.class, 1000.00);
!
! // double PI^300
! // = 13962455701329742638131355433930076081862072808 ... e+149
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
! test("%.3g", "10.0", ten);
! test("%.3g", "1.00", one);
! test("%10.3g", " 1.00", one);
! test("%+10.3g", " +3.14", pi);
! test("%+10.3g", " -3.14", negate(pi));
! test("% .3g", " 3.14", pi);
! test("% .3g", "-3.14", negate(pi));
! test("%.0g", "3", create(3.0));
! test("%.0g", "-3", create(-3.0));
!
! test("%(.4g", "3.142e+08", mult(pi, 100000000.0));
! test("%(.4g", "(3.142e+08)", mult(pi, -100000000.0));
!
!
!
!
!
!
!
! test("%,.11g", "3,141,592.6536", mult(pi, 1000000.0));
! test("%(,.11g", "(3,141,592.6536)", mult(pi, -1000000.0));
!
//---------------------------------------------------------------------
! // %a
//
// Floating-point conversions applicable to float, double, and
// BigDecimal.
//---------------------------------------------------------------------
! test("%a", "null", (Object)null);
! test("%.11a", "0x0.00000000000p0", 0.0);
! test(Locale.FRANCE, "%.11a", "0x0.00000000000p0", 0.0); // no localization
! test("%.1a", "0x0.0p0", 0.0);
! test("%.11a", "-0x0.00000000000p0", -0.0);
! test("%.1a", "-0x0.0p0", -0.0);
! test("%.11a", "0x1.00000000000p0", 1.0);
! test("%.1a", "0x1.0p0", 1.0);
! test("%.11a", "-0x1.00000000000p0", -1.0);
! test("%.1a", "-0x1.0p0", -1.0);
! test("%.11a", "0x1.80000000000p1", 3.0);
! test("%.1a", "0x1.8p1", 3.0);
! test("%.11a", "0x1.00000000000p-1022", Double.MIN_NORMAL);
! test("%.1a", "0x1.0p-1022", Double.MIN_NORMAL);
! test("%.11a", "0x1.00000000000p-1022",
! Math.nextDown(Double.MIN_NORMAL));
! test("%.1a", "0x1.0p-1022",
! Math.nextDown(Double.MIN_NORMAL));
! test("%.11a", "0x1.ffffffffffep-1023", 0x0.fffffffffffp-1022);
! test("%.1a", "0x1.0p-1022", 0x0.fffffffffffp-1022);
! test("%.30a", "0x0.000000000000100000000000000000p-1022", Double.MIN_VALUE);
! test("%.13a", "0x0.0000000000001p-1022", Double.MIN_VALUE);
! test("%.11a", "0x1.00000000000p-1074", Double.MIN_VALUE);
! test("%.1a", "0x1.0p-1074", Double.MIN_VALUE);
!
! test("%.11a", "0x1.08000000000p-1069",
! Double.MIN_VALUE + Double.MIN_VALUE*32);
! test("%.1a", "0x1.0p-1069",
! Double.MIN_VALUE + Double.MIN_VALUE*32);
! test("%.30a", "0x1.fffffffffffff00000000000000000p1023", Double.MAX_VALUE);
! test("%.13a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
! test("%.11a", "0x1.00000000000p1024", Double.MAX_VALUE);
! test("%.1a", "0x1.0p1024", Double.MAX_VALUE);
! test("%.11a", "0x1.18000000000p0", 0x1.18p0);
! test("%.1a", "0x1.2p0", 0x1.18p0);
!
! test("%.11a", "0x1.18000000000p0", 0x1.180000000001p0);
! test("%.1a", "0x1.2p0", 0x1.180000000001p0);
! test("%.11a", "0x1.28000000000p0", 0x1.28p0);
! test("%.1a", "0x1.2p0", 0x1.28p0);
!
! test("%.11a", "0x1.28000000000p0", 0x1.280000000001p0);
! test("%.1a", "0x1.3p0", 0x1.280000000001p0);
!
! test("%a", "0x0.123p-1022", 0x0.123p-1022);
! test("%1.3a", "0x1.230p-1026", 0x0.123p-1022);
! test("%1.12a", "0x1.230000000000p-1026", 0x0.123p-1022);
! test("%1.15a", "0x0.123000000000000p-1022", 0x0.123p-1022);
! test("%1.5a", "0x1.00000p-1074", 0x0.0000000000001p-1022);
! test("%1.7a", "0x1.0000000p-1022", 0x0.fffffffffffffp-1022);
!
! test("%1.6a", "0x1.230000p-1026", 0x0.123000057p-1022);
! test("%1.7a", "0x1.2300005p-1026", 0x0.123000057p-1022);
! test("%1.8a", "0x1.23000057p-1026", 0x0.123000057p-1022);
! test("%1.9a", "0x1.230000570p-1026", 0x0.123000057p-1022);
!
! test("%1.6a", "0x1.230000p-1026", 0x0.123000058p-1022);
! test("%1.7a", "0x1.2300006p-1026", 0x0.123000058p-1022);
! test("%1.8a", "0x1.23000058p-1026", 0x0.123000058p-1022);
! test("%1.9a", "0x1.230000580p-1026", 0x0.123000058p-1022);
!
! test("%1.6a", "0x1.230000p-1026", 0x0.123000059p-1022);
! test("%1.7a", "0x1.2300006p-1026", 0x0.123000059p-1022);
! test("%1.8a", "0x1.23000059p-1026", 0x0.123000059p-1022);
! test("%1.9a", "0x1.230000590p-1026", 0x0.123000059p-1022);
!
! test("%1.4a", "0x1.0000p-1022", Math.nextDown(Double.MIN_NORMAL));
!
! test("%a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
! test("%1.1a", "0x1.0p1024", Double.MAX_VALUE);
! test("%1.2a", "0x1.00p1024", Double.MAX_VALUE);
! test("%1.6a", "0x1.000000p1024", Double.MAX_VALUE);
! test("%1.9a", "0x1.000000000p1024", Double.MAX_VALUE);
! test("%1.11a", "0x1.00000000000p1024", Double.MAX_VALUE);
! test("%1.12a", "0x1.000000000000p1024", Double.MAX_VALUE);
! test("%1.13a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
!
!
!
! //---------------------------------------------------------------------
! // %f, %e, %g, %a - Boundaries
! //---------------------------------------------------------------------
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
!
//---------------------------------------------------------------------
// %f, %e, %g, %a - Double.MIN_VALUE
//---------------------------------------------------------------------
test("%f", "0.000000", Double.MIN_VALUE);
--- 337,692 ----
//---------------------------------------------------------------------
tryCatch("%F", UnknownFormatConversionException.class);
tryCatch("%#g", FormatFlagsConversionMismatchException.class);
+ //---------------------------------------------------------------------
+ // %s - double
+ //---------------------------------------------------------------------
+ double one = 1.0;
+ double ten = 10.0;
+ double pi = Math.PI;
+ test("%s", "3.141592653589793", pi);
+ //---------------------------------------------------------------------
+ // flag/conversion errors
+ //---------------------------------------------------------------------
+ tryCatch("%d", IllegalFormatConversionException.class, one);
+ tryCatch("%,.4e", FormatFlagsConversionMismatchException.class, one);
+ //---------------------------------------------------------------------
+ // %e
+ //
+ // Floating-point conversions applicable to float, double, and
+ // BigDecimal.
+ //---------------------------------------------------------------------
+ test("%e", "null", (Object)null);
+ //---------------------------------------------------------------------
+ // %e - float and double
+ //---------------------------------------------------------------------
+ // double PI = 3.141 592 653 589 793 238 46;
+ test("%e", "3.141593e+00", pi);
+ test("%.0e", "1e+01", ten);
+ test("%#.0e", "1.e+01", ten);
+ test("%E", "3.141593E+00", pi);
+ test("%10.3e", " 3.142e+00", pi);
+ test("%10.3e", "-3.142e+00", negate(pi));
+ test("%010.3e", "03.142e+00", pi);
+ test("%010.3e", "-3.142e+00", negate(pi));
+ test("%-12.3e", "3.142e+00 ", pi);
+ test("%-12.3e", "-3.142e+00 ", negate(pi));
+ test("%.3e", "3.142e+00", pi);
+ test("%.3e", "-3.142e+00", negate(pi));
+ test("%.3e", "3.142e+06", mult(pi, 1000000.0));
+ test("%.3e", "-3.142e+06", mult(pi, -1000000.0));
+ test(Locale.FRANCE, "%e", "3,141593e+00", pi);
+ // double PI^300
+ // = 13962455701329742638131355433930076081862072808 ... e+149
+ test("%10.3e", " 1.000e+00", one);
+ test("%+.3e", "+3.142e+00", pi);
+ test("%+.3e", "-3.142e+00", negate(pi));
+ test("% .3e", " 3.142e+00", pi);
+ test("% .3e", "-3.142e+00", negate(pi));
+ test("%#.0e", "3.e+00", create(3.0));
+ test("%#.0e", "-3.e+00", create(-3.0));
+ test("%.0e", "3e+00", create(3.0));
+ test("%.0e", "-3e+00", create(-3.0));
! test("%(.4e", "3.1416e+06", mult(pi, 1000000.0));
! test("%(.4e", "(3.1416e+06)", mult(pi, -1000000.0));
//---------------------------------------------------------------------
! // %e - boundary problems
//---------------------------------------------------------------------
! test("%3.0e", "1e-06", 0.000001);
! test("%3.0e", "1e-05", 0.00001);
! test("%3.0e", "1e-04", 0.0001);
! test("%3.0e", "1e-03", 0.001);
! test("%3.0e", "1e-02", 0.01);
! test("%3.0e", "1e-01", 0.1);
! test("%3.0e", "9e-01", 0.9);
! test("%3.1e", "9.0e-01", 0.9);
! test("%3.0e", "1e+00", 1.00);
! test("%3.0e", "1e+01", 10.00);
! test("%3.0e", "1e+02", 99.19);
! test("%3.1e", "9.9e+01", 99.19);
! test("%3.0e", "1e+02", 99.99);
! test("%3.0e", "1e+02", 100.00);
! test("%#3.0e", "1.e+03", 1000.00);
! test("%3.0e", "1e+04", 10000.00);
! test("%3.0e", "1e+05", 100000.00);
! test("%3.0e", "1e+06", 1000000.00);
! test("%3.0e", "1e+07", 10000000.00);
! test("%3.0e", "1e+08", 100000000.00);
//---------------------------------------------------------------------
! // %f
//
// Floating-point conversions applicable to float, double, and
// BigDecimal.
//---------------------------------------------------------------------
! test("%f", "null", (Object)null);
! test("%f", "3.141593", pi);
! test(Locale.FRANCE, "%f", "3,141593", pi);
! test("%10.3f", " 3.142", pi);
! test("%10.3f", " -3.142", negate(pi));
! test("%010.3f", "000003.142", pi);
! test("%010.3f", "-00003.142", negate(pi));
! test("%-10.3f", "3.142 ", pi);
! test("%-10.3f", "-3.142 ", negate(pi));
! test("%.3f", "3.142", pi);
! test("%.3f", "-3.142", negate(pi));
! test("%+.3f", "+3.142", pi);
! test("%+.3f", "-3.142", negate(pi));
! test("% .3f", " 3.142", pi);
! test("% .3f", "-3.142", negate(pi));
! test("%#.0f", "3.", create(3.0));
! test("%#.0f", "-3.", create(-3.0));
! test("%.0f", "3", create(3.0));
! test("%.0f", "-3", create(-3.0));
! test("%.3f", "10.000", ten);
! test("%.3f", "1.000", one);
! test("%10.3f", " 1.000", one);
+ //---------------------------------------------------------------------
+ // %f - boundary problems
+ //---------------------------------------------------------------------
+ test("%3.0f", " 0", 0.000001);
+ test("%3.0f", " 0", 0.00001);
+ test("%3.0f", " 0", 0.0001);
+ test("%3.0f", " 0", 0.001);
+ test("%3.0f", " 0", 0.01);
+ test("%3.0f", " 0", 0.1);
+ test("%3.0f", " 1", 0.9);
+ test("%3.1f", "0.9", 0.9);
+ test("%3.0f", " 1", 1.00);
+ test("%3.0f", " 10", 10.00);
+ test("%3.0f", " 99", 99.19);
+ test("%3.1f", "99.2", 99.19);
+ test("%3.0f", "100", 99.99);
+ test("%3.0f", "100", 100.00);
+ test("%#3.0f", "1000.", 1000.00);
+ test("%3.0f", "10000", 10000.00);
+ test("%3.0f", "100000", 100000.00);
+ test("%3.0f", "1000000", 1000000.00);
+ test("%3.0f", "10000000", 10000000.00);
+ test("%3.0f", "100000000", 100000000.00);
+ test("%10.0f", " 1000000", 1000000.00);
+ test("%,10.0f", " 1,000,000", 1000000.00);
+ test("%,10.1f", "1,000,000.0", 1000000.00);
+ test("%,3.0f", "1,000,000", 1000000.00);
+ test("%,3.0f", "10,000,000", 10000000.00);
+ test("%,3.0f", "100,000,000", 100000000.00);
+ test("%,3.0f", "10,000,000", 10000000.00);
+ test("%,3.0f", "100,000,000", 100000000.00);
+ //---------------------------------------------------------------------
+ // %f - float, double, Double, BigDecimal
+ //---------------------------------------------------------------------
+ test("%.3f", "3141592.654", mult(pi, 1000000.0));
+ test("%.3f", "-3141592.654", mult(pi, -1000000.0));
+ test("%,.4f", "3,141,592.6536", mult(pi, 1000000.0));
+ test(Locale.FRANCE, "%,.4f", "3\u00a0141\u00a0592,6536", mult(pi, 1000000.0));
+ test("%,.4f", "-3,141,592.6536", mult(pi, -1000000.0));
+ test("%(.4f", "3141592.6536", mult(pi, 1000000.0));
+ test("%(.4f", "(3141592.6536)", mult(pi, -1000000.0));
+ test("%(,.4f", "3,141,592.6536", mult(pi, 1000000.0));
+ test("%(,.4f", "(3,141,592.6536)", mult(pi, -1000000.0));
//---------------------------------------------------------------------
! // %g
//
// Floating-point conversions applicable to float, double, and
// BigDecimal.
//---------------------------------------------------------------------
! test("%g", "null", (Object)null);
! test("%g", "3.14159", pi);
! test(Locale.FRANCE, "%g", "3,14159", pi);
! test("%.0g", "1e+01", ten);
! test("%G", "3.14159", pi);
! test("%10.3g", " 3.14", pi);
! test("%10.3g", " -3.14", negate(pi));
! test("%010.3g", "0000003.14", pi);
! test("%010.3g", "-000003.14", negate(pi));
! test("%-12.3g", "3.14 ", pi);
! test("%-12.3g", "-3.14 ", negate(pi));
! test("%.3g", "3.14", pi);
! test("%.3g", "-3.14", negate(pi));
! test("%.3g", "3.14e+08", mult(pi, 100000000.0));
! test("%.3g", "-3.14e+08", mult(pi, -100000000.0));
+ test("%.3g", "1.00e-05", recip(create(100000.0)));
+ test("%.3g", "-1.00e-05", recip(create(-100000.0)));
+ test("%.0g", "-1e-05", recip(create(-100000.0)));
+ test("%.0g", "1e+05", create(100000.0));
+ test("%.3G", "1.00E-05", recip(create(100000.0)));
+ test("%.3G", "-1.00E-05", recip(create(-100000.0)));
+ test("%.1g", "-0", -0.0);
+ test("%3.0g", " -0", -0.0);
+ test("%.1g", "0", 0.0);
+ test("%3.0g", " 0", 0.0);
+ test("%.1g", "0", +0.0);
+ test("%3.0g", " 0", +0.0);
+ test("%3.0g", "1e-06", 0.000001);
+ test("%3.0g", "1e-05", 0.00001);
+ test("%3.0g", "1e-05", 0.0000099);
+ test("%3.1g", "1e-05", 0.0000099);
+ test("%3.2g", "9.9e-06", 0.0000099);
+ test("%3.0g", "0.0001", 0.0001);
+ test("%3.0g", "9e-05", 0.00009);
+ test("%3.0g", "0.0001", 0.000099);
+ test("%3.1g", "0.0001", 0.000099);
+ test("%3.2g", "9.9e-05", 0.000099);
+ test("%3.0g", "0.001", 0.001);
+ test("%3.0g", "0.001", 0.00099);
+ test("%3.1g", "0.001", 0.00099);
+ test("%3.2g", "0.00099", 0.00099);
+ test("%3.3g", "0.00100", 0.001);
+ test("%3.4g", "0.001000", 0.001);
+ test("%3.0g", "0.01", 0.01);
+ test("%3.0g", "0.1", 0.1);
+ test("%3.0g", "0.9", 0.9);
+ test("%3.1g", "0.9", 0.9);
+ test("%3.0g", " 1", 1.00);
+ test("%3.2g", " 10", 10.00);
+ test("%3.0g", "1e+01", 10.00);
+ test("%3.0g", "1e+02", 99.19);
+ test("%3.1g", "1e+02", 99.19);
+ test("%3.2g", " 99", 99.19);
+ test("%3.0g", "1e+02", 99.9);
+ test("%3.1g", "1e+02", 99.9);
+ test("%3.2g", "1.0e+02", 99.9);
+ test("%3.0g", "1e+02", 99.99);
+ test("%3.0g", "1e+02", 100.00);
+ test("%3.0g", "1e+03", 999.9);
+ test("%3.1g", "1e+03", 999.9);
+ test("%3.2g", "1.0e+03", 999.9);
+ test("%3.3g", "1.00e+03", 999.9);
+ test("%3.4g", "999.9", 999.9);
+ test("%3.4g", "1000", 999.99);
+ test("%3.0g", "1e+03", 1000.00);
+ test("%3.0g", "1e+04", 10000.00);
+ test("%3.0g", "1e+05", 100000.00);
+ test("%3.0g", "1e+06", 1000000.00);
+ test("%3.0g", "1e+07", 10000000.00);
+ test("%3.9g", "100000000", 100000000.00);
+ test("%3.10g", "100000000.0", 100000000.00);
+ tryCatch("%#3.0g", FormatFlagsConversionMismatchException.class, 1000.00);
+ // double PI^300
+ // = 13962455701329742638131355433930076081862072808 ... e+149
+ test("%.3g", "10.0", ten);
+ test("%.3g", "1.00", one);
+ test("%10.3g", " 1.00", one);
+ test("%+10.3g", " +3.14", pi);
+ test("%+10.3g", " -3.14", negate(pi));
+ test("% .3g", " 3.14", pi);
+ test("% .3g", "-3.14", negate(pi));
+ test("%.0g", "3", create(3.0));
+ test("%.0g", "-3", create(-3.0));
+ test("%(.4g", "3.142e+08", mult(pi, 100000000.0));
+ test("%(.4g", "(3.142e+08)", mult(pi, -100000000.0));
+ test("%,.11g", "3,141,592.6536", mult(pi, 1000000.0));
+ test("%(,.11g", "(3,141,592.6536)", mult(pi, -1000000.0));
+ //---------------------------------------------------------------------
+ // %a
+ //
+ // Floating-point conversions applicable to float, double, and
+ // BigDecimal.
+ //---------------------------------------------------------------------
+ test("%a", "null", (Object)null);
+ test("%.11a", "0x0.00000000000p0", 0.0);
+ test(Locale.FRANCE, "%.11a", "0x0.00000000000p0", 0.0); // no localization
+ test("%.1a", "0x0.0p0", 0.0);
+ test("%.11a", "-0x0.00000000000p0", -0.0);
+ test("%.1a", "-0x0.0p0", -0.0);
+ test("%.11a", "0x1.00000000000p0", 1.0);
+ test("%.1a", "0x1.0p0", 1.0);
+ test("%.11a", "-0x1.00000000000p0", -1.0);
+ test("%.1a", "-0x1.0p0", -1.0);
+ test("%.11a", "0x1.80000000000p1", 3.0);
+ test("%.1a", "0x1.8p1", 3.0);
+ test("%.11a", "0x1.00000000000p-1022", DoubleConsts.MIN_NORMAL);
+ test("%.1a", "0x1.0p-1022", DoubleConsts.MIN_NORMAL);
+ test("%.11a", "0x1.00000000000p-1022",
+ Math.nextDown(DoubleConsts.MIN_NORMAL));
+ test("%.1a", "0x1.0p-1022",
+ Math.nextDown(DoubleConsts.MIN_NORMAL));
+ test("%.11a", "0x1.ffffffffffep-1023", 0x0.fffffffffffp-1022);
+ test("%.1a", "0x1.0p-1022", 0x0.fffffffffffp-1022);
+ test("%.30a", "0x0.000000000000100000000000000000p-1022", Double.MIN_VALUE);
+ test("%.13a", "0x0.0000000000001p-1022", Double.MIN_VALUE);
+ test("%.11a", "0x1.00000000000p-1074", Double.MIN_VALUE);
+ test("%.1a", "0x1.0p-1074", Double.MIN_VALUE);
+ test("%.11a", "0x1.08000000000p-1069",
+ Double.MIN_VALUE + Double.MIN_VALUE*32);
+ test("%.1a", "0x1.0p-1069",
+ Double.MIN_VALUE + Double.MIN_VALUE*32);
+ test("%.30a", "0x1.fffffffffffff00000000000000000p1023", Double.MAX_VALUE);
+ test("%.13a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
+ test("%.11a", "0x1.00000000000p1024", Double.MAX_VALUE);
+ test("%.1a", "0x1.0p1024", Double.MAX_VALUE);
+ test("%.11a", "0x1.18000000000p0", 0x1.18p0);
+ test("%.1a", "0x1.2p0", 0x1.18p0);
+ test("%.11a", "0x1.18000000000p0", 0x1.180000000001p0);
+ test("%.1a", "0x1.2p0", 0x1.180000000001p0);
+ test("%.11a", "0x1.28000000000p0", 0x1.28p0);
+ test("%.1a", "0x1.2p0", 0x1.28p0);
+ test("%.11a", "0x1.28000000000p0", 0x1.280000000001p0);
+ test("%.1a", "0x1.3p0", 0x1.280000000001p0);
+ test("%a", "0x0.123p-1022", 0x0.123p-1022);
+ test("%1.3a", "0x1.230p-1026", 0x0.123p-1022);
+ test("%1.12a", "0x1.230000000000p-1026", 0x0.123p-1022);
+ test("%1.15a", "0x0.123000000000000p-1022", 0x0.123p-1022);
+ test("%1.5a", "0x1.00000p-1074", 0x0.0000000000001p-1022);
+ test("%1.7a", "0x1.0000000p-1022", 0x0.fffffffffffffp-1022);
+ test("%1.6a", "0x1.230000p-1026", 0x0.123000057p-1022);
+ test("%1.7a", "0x1.2300005p-1026", 0x0.123000057p-1022);
+ test("%1.8a", "0x1.23000057p-1026", 0x0.123000057p-1022);
+ test("%1.9a", "0x1.230000570p-1026", 0x0.123000057p-1022);
+ test("%1.6a", "0x1.230000p-1026", 0x0.123000058p-1022);
+ test("%1.7a", "0x1.2300006p-1026", 0x0.123000058p-1022);
+ test("%1.8a", "0x1.23000058p-1026", 0x0.123000058p-1022);
+ test("%1.9a", "0x1.230000580p-1026", 0x0.123000058p-1022);
+ test("%1.6a", "0x1.230000p-1026", 0x0.123000059p-1022);
+ test("%1.7a", "0x1.2300006p-1026", 0x0.123000059p-1022);
+ test("%1.8a", "0x1.23000059p-1026", 0x0.123000059p-1022);
+ test("%1.9a", "0x1.230000590p-1026", 0x0.123000059p-1022);
+ test("%1.4a", "0x1.0000p-1022", Math.nextDown(Double.MIN_NORMAL));
+ test("%a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
+ test("%1.1a", "0x1.0p1024", Double.MAX_VALUE);
+ test("%1.2a", "0x1.00p1024", Double.MAX_VALUE);
+ test("%1.6a", "0x1.000000p1024", Double.MAX_VALUE);
+ test("%1.9a", "0x1.000000000p1024", Double.MAX_VALUE);
+ test("%1.11a", "0x1.00000000000p1024", Double.MAX_VALUE);
+ test("%1.12a", "0x1.000000000000p1024", Double.MAX_VALUE);
+ test("%1.13a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
+ //---------------------------------------------------------------------
+ // %f, %e, %g, %a - Boundaries
+ //---------------------------------------------------------------------
//---------------------------------------------------------------------
// %f, %e, %g, %a - Double.MIN_VALUE
//---------------------------------------------------------------------
test("%f", "0.000000", Double.MIN_VALUE);
*** 1610,1622 ****
test("%30.20g", " 1.7976931348623157000e+308", Double.MAX_VALUE);
test("%a", "0x1.fffffffffffffp1023", Double.MAX_VALUE);
test("%A", "0X1.FFFFFFFFFFFFFP1023", Double.MAX_VALUE);
test("%30a", " 0x1.fffffffffffffp1023", Double.MAX_VALUE);
-
-
-
//---------------------------------------------------------------------
// %t
//
// Date/Time conversions applicable to Calendar, Date, and long.
//---------------------------------------------------------------------
--- 747,756 ----
*** 1632,1735 ****
tryCatch("%TP", UnknownFormatConversionException.class);
tryCatch("%.5tB", IllegalFormatPrecisionException.class);
tryCatch("%#tB", FormatFlagsConversionMismatchException.class);
tryCatch("%-tB", MissingFormatWidthException.class);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
//---------------------------------------------------------------------
// %n
//---------------------------------------------------------------------
test("%n", System.getProperty("line.separator"), (Object)null);
test("%n", System.getProperty("line.separator"), "");
--- 766,775 ----