Test for multibyte thousand seperator handling in strtod.
authordrepper <drepper>
Thu, 11 Jan 2007 17:36:58 +0000 (17:36 +0000)
committerdrepper <drepper>
Thu, 11 Jan 2007 17:36:58 +0000 (17:36 +0000)
stdlib/tst-strtod4.c [new file with mode: 0644]

diff --git a/stdlib/tst-strtod4.c b/stdlib/tst-strtod4.c
new file mode 100644 (file)
index 0000000..2d9d54c
--- /dev/null
@@ -0,0 +1,56 @@
+#include <locale.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+#define NBSP "\xc2\xa0"
+
+static const struct
+{
+  const char *in;
+  const char *out;
+  double expected;
+} tests[] =
+  {
+    { "000"NBSP"000"NBSP"000", "", 0.0 },
+    { "1"NBSP"000"NBSP"000,5x", "x", 1000000.5 }
+  };
+#define NTESTS (sizeof (tests) / sizeof (tests[0]))
+
+
+static int
+do_test (void)
+{
+  if (setlocale (LC_ALL, "cs_CZ.UTF-8") == NULL)
+    {
+      puts ("could not set locale");
+      return 1;
+    }
+
+  int status = 0;
+
+  for (int i = 0; i < NTESTS; ++i)
+    {
+      char *ep;
+      double r = __strtod_internal (tests[i].in, &ep, 1);
+
+      if (strcmp (ep, tests[i].out) != 0)
+       {
+         printf ("%d: got rest string \"%s\", expected \"%s\"\n",
+                 i, ep, tests[i].out);
+         status = 1;
+       }
+
+      if (r != tests[i].expected)
+       {
+         printf ("%d: got wrong results %g, expected %g\n",
+                 i, r, tests[i].expected);
+         status = 1;
+       }
+    }
+
+  return status;
+}
+
+#define TEST_FUNCTION do_test ()
+#include "../test-skeleton.c"