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 ----