# define NaN() (0.0 / 0.0)
#endif
+/* The SGI MIPS floating-point format does not distinguish 0.0 and -0.0. */
+static int
+have_minus_zero ()
+{
+ static double plus_zero = 0.0;
+ static double minus_zero = -0.0;
+ return memcmp (&plus_zero, &minus_zero, sizeof (double)) != 0;
+}
+
static int
strmatch (const char *pattern, const char *string)
{
char result[1000];
int retval =
my_sprintf (result, "%a %d", -0.0, 33, 44, 55);
- ASSERT (strcmp (result, "-0x0p+0 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0x0p+0 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%a %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
{ /* FLAG_ZERO with NaN. */
char result[1000];
int retval =
- my_sprintf (result, "%010a %d", NaN (), 33, 44, 55);
+ my_sprintf (result, "%020a %d", NaN (), 33, 44, 55);
/* "0000000nan 33" is not a valid result; see
<http://lists.gnu.org/archive/html/bug-gnulib/2007-04/msg00107.html> */
- ASSERT (strcmp (result, " nan 33") == 0);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%La %d", -0.0L, 33, 44, 55);
- ASSERT (strcmp (result, "-0x0p+0 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0x0p+0 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%La %d", 0.0L / 0.0L, 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
{ /* FLAG_ZERO with NaN. */
char result[1000];
int retval =
- my_sprintf (result, "%010La %d", 0.0L / 0.0L, 33, 44, 55);
+ my_sprintf (result, "%020La %d", 0.0L / 0.0L, 33, 44, 55);
/* "0000000nan 33" is not a valid result; see
<http://lists.gnu.org/archive/html/bug-gnulib/2007-04/msg00107.html> */
- ASSERT (strcmp (result, " nan 33") == 0);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%f %d", -0.0, 33, 44, 55);
- ASSERT (strcmp (result, "-0.000000 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0.000000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%f %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
{ /* FLAG_ZERO with NaN. */
char result[1000];
int retval =
- my_sprintf (result, "%015f %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, " nan 33") == 0);
+ my_sprintf (result, "%020f %d", NaN (), 33, 44, 55);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%Lf %d", -0.0L, 33, 44, 55);
- ASSERT (strcmp (result, "-0.000000 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0.000000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%Lf %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
static long double zero = 0.0L;
char result[1000];
int retval =
- my_sprintf (result, "%015Lf %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, " nan 33") == 0);
+ my_sprintf (result, "%020Lf %d", zero / zero, 33, 44, 55);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%F %d", -0.0, 33, 44, 55);
- ASSERT (strcmp (result, "-0.000000 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0.000000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%F %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, "NAN 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "NAN", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%LF %d", -0.0L, 33, 44, 55);
- ASSERT (strcmp (result, "-0.000000 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0.000000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%LF %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, "NAN 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "NAN", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%e %d", 12.75, 33, 44, 55);
- ASSERT (strcmp (result, "1.275000e+01 33") == 0);
+ ASSERT (strcmp (result, "1.275000e+01 33") == 0
+ || strcmp (result, "1.275000e+001 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%e %d", 1234567.0, 33, 44, 55);
- ASSERT (strcmp (result, "1.234567e+06 33") == 0);
+ ASSERT (strcmp (result, "1.234567e+06 33") == 0
+ || strcmp (result, "1.234567e+006 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%e", data[k].value);
- ASSERT (strmatch (data[k].string, result));
+ const char *expected = data[k].string;
+ ASSERT (result != NULL);
+ ASSERT (strcmp (result, expected) == 0
+ /* Some implementations produce exponents with 3 digits. */
+ || (strlen (result) == strlen (expected) + 1
+ && memcmp (result, expected, strlen (expected) - 2) == 0
+ && result[strlen (expected) - 2] == '0'
+ && strcmp (result + strlen (expected) - 1,
+ expected + strlen (expected) - 2)
+ == 0));
ASSERT (retval == strlen (result));
}
}
char result[1000];
int retval =
my_sprintf (result, "%e %d", -0.03125, 33, 44, 55);
- ASSERT (strcmp (result, "-3.125000e-02 33") == 0);
+ ASSERT (strcmp (result, "-3.125000e-02 33") == 0
+ || strcmp (result, "-3.125000e-002 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%e %d", 0.0, 33, 44, 55);
- ASSERT (strcmp (result, "0.000000e+00 33") == 0);
+ ASSERT (strcmp (result, "0.000000e+00 33") == 0
+ || strcmp (result, "0.000000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%e %d", -0.0, 33, 44, 55);
- ASSERT (strcmp (result, "-0.000000e+00 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0.000000e+00 33") == 0
+ || strcmp (result, "-0.000000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%e %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%15e %d", 1.75, 33, 44, 55);
- ASSERT (strcmp (result, " 1.750000e+00 33") == 0);
+ ASSERT (strcmp (result, " 1.750000e+00 33") == 0
+ || strcmp (result, " 1.750000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%-15e %d", 1.75, 33, 44, 55);
- ASSERT (strcmp (result, "1.750000e+00 33") == 0);
+ ASSERT (strcmp (result, "1.750000e+00 33") == 0
+ || strcmp (result, "1.750000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%+e %d", 1.75, 33, 44, 55);
- ASSERT (strcmp (result, "+1.750000e+00 33") == 0);
+ ASSERT (strcmp (result, "+1.750000e+00 33") == 0
+ || strcmp (result, "+1.750000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "% e %d", 1.75, 33, 44, 55);
- ASSERT (strcmp (result, " 1.750000e+00 33") == 0);
+ ASSERT (strcmp (result, " 1.750000e+00 33") == 0
+ || strcmp (result, " 1.750000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%#e %d", 1.75, 33, 44, 55);
- ASSERT (strcmp (result, "1.750000e+00 33") == 0);
+ ASSERT (strcmp (result, "1.750000e+00 33") == 0
+ || strcmp (result, "1.750000e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%#.e %d", 1.75, 33, 44, 55);
- ASSERT (strcmp (result, "2.e+00 33") == 0);
+ ASSERT (strcmp (result, "2.e+00 33") == 0
+ || strcmp (result, "2.e+000 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%#.e %d", 9.75, 33, 44, 55);
- ASSERT (strcmp (result, "1.e+01 33") == 0);
+ ASSERT (strcmp (result, "1.e+01 33") == 0
+ || strcmp (result, "1.e+001 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%015e %d", 1234.0, 33, 44, 55);
- ASSERT (strcmp (result, "0001.234000e+03 33") == 0);
+ ASSERT (strcmp (result, "0001.234000e+03 33") == 0
+ || strcmp (result, "001.234000e+003 33") == 0);
ASSERT (retval == strlen (result));
}
{ /* FLAG_ZERO with NaN. */
char result[1000];
int retval =
- my_sprintf (result, "%015e %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, " nan 33") == 0);
+ my_sprintf (result, "%020e %d", NaN (), 33, 44, 55);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%.e %d", 1234.0, 33, 44, 55);
- ASSERT (strcmp (result, "1e+03 33") == 0);
+ ASSERT (strcmp (result, "1e+03 33") == 0
+ || strcmp (result, "1e+003 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%Le", data[k].value);
- ASSERT (strmatch (data[k].string, result));
+ ASSERT (strcmp (result, data[k].string) == 0);
ASSERT (retval == strlen (result));
}
}
char result[1000];
int retval =
my_sprintf (result, "%Le %d", -0.0L, 33, 44, 55);
- ASSERT (strcmp (result, "-0.000000e+00 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0.000000e+00 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%Le %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
static long double zero = 0.0L;
char result[1000];
int retval =
- my_sprintf (result, "%015Le %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, " nan 33") == 0);
+ my_sprintf (result, "%020Le %d", zero / zero, 33, 44, 55);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%g %d", 1234567.0, 33, 44, 55);
- ASSERT (strcmp (result, "1.23457e+06 33") == 0);
+ ASSERT (strcmp (result, "1.23457e+06 33") == 0
+ || strcmp (result, "1.23457e+006 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%g", data[k].value);
- ASSERT (strmatch (data[k].string, result));
+ const char *expected = data[k].string;
+ ASSERT (strcmp (result, expected) == 0
+ /* Some implementations produce exponents with 3 digits. */
+ || (expected[strlen (expected) - 4] == 'e'
+ && strlen (result) == strlen (expected) + 1
+ && memcmp (result, expected, strlen (expected) - 2) == 0
+ && result[strlen (expected) - 2] == '0'
+ && strcmp (result + strlen (expected) - 1,
+ expected + strlen (expected) - 2)
+ == 0));
ASSERT (retval == strlen (result));
}
}
char result[1000];
int retval =
my_sprintf (result, "%g %d", -0.0, 33, 44, 55);
- ASSERT (strcmp (result, "-0 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%g %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%#.g %d", 9.75, 33, 44, 55);
- ASSERT (strcmp (result, "1.e+01 33") == 0);
+ ASSERT (strcmp (result, "1.e+01 33") == 0
+ || strcmp (result, "1.e+001 33") == 0);
ASSERT (retval == strlen (result));
}
{ /* FLAG_ZERO with NaN. */
char result[1000];
int retval =
- my_sprintf (result, "%015g %d", NaN (), 33, 44, 55);
- ASSERT (strcmp (result, " nan 33") == 0);
+ my_sprintf (result, "%020g %d", NaN (), 33, 44, 55);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%.g %d", 1234.0, 33, 44, 55);
- ASSERT (strcmp (result, "1e+03 33") == 0);
+ ASSERT (strcmp (result, "1e+03 33") == 0
+ || strcmp (result, "1e+003 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%Lg", data[k].value);
- ASSERT (strmatch (data[k].string, result));
+ ASSERT (strcmp (result, data[k].string) == 0);
ASSERT (retval == strlen (result));
}
}
char result[1000];
int retval =
my_sprintf (result, "%Lg %d", -0.0L, 33, 44, 55);
- ASSERT (strcmp (result, "-0 33") == 0);
+ if (have_minus_zero ())
+ ASSERT (strcmp (result, "-0 33") == 0);
ASSERT (retval == strlen (result));
}
char result[1000];
int retval =
my_sprintf (result, "%Lg %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, "nan 33") == 0);
+ ASSERT (strlen (result) >= 3 + 3
+ && memcmp (result, "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}
static long double zero = 0.0L;
char result[1000];
int retval =
- my_sprintf (result, "%015Lg %d", zero / zero, 33, 44, 55);
- ASSERT (strcmp (result, " nan 33") == 0);
+ my_sprintf (result, "%020Lg %d", zero / zero, 33, 44, 55);
+ ASSERT (strlen (result) == 20 + 3
+ && memcmp (result + strspn (result, " "), "nan", 3) == 0
+ && strcmp (result + strlen (result) - 3, " 33") == 0);
ASSERT (retval == strlen (result));
}