12 { "1e308", "1e+308" },
13 { "100000000e300", "1e+308" },
14 { "0x1p1023", "8.98847e+307" },
15 { "0x1000p1011", "8.98847e+307" },
16 { "0x1p1020", "1.12356e+307" },
17 { "0x0.00001p1040", "1.12356e+307" },
18 { "1e-307", "1e-307" },
19 { "0.000001e-301", "1e-307" },
20 { "0.0000001e-300", "1e-307" },
21 { "0.00000001e-299", "1e-307" },
22 { "1000000e-313", "1e-307" },
23 { "10000000e-314", "1e-307" },
24 { "100000000e-315", "1e-307" },
25 { "0x1p-1021", "4.45015e-308" },
26 { "0x1000p-1033", "4.45015e-308" },
27 { "0x10000p-1037", "4.45015e-308" },
28 { "0x0.001p-1009", "4.45015e-308" },
29 { "0x0.0001p-1005", "4.45015e-308" },
31 #define NTESTS (sizeof (tests) / sizeof (tests[0]))
39 for (int i = 0; i < NTESTS; ++i)
42 snprintf (buf, sizeof (buf), "%g", atof (tests[i].str));
43 if (strcmp (buf, tests[i].expected) != 0)
45 printf ("%d: got \"%s\", expected \"%s\"\n",
46 i, buf, tests[i].expected);
54 #define TEST_FUNCTION do_test ()
55 #include "../test-skeleton.c"