Fix test failure on OpenBSD 4.0.
authorBruno Haible <bruno@clisp.org>
Thu, 10 Jan 2008 01:36:58 +0000 (02:36 +0100)
committerBruno Haible <bruno@clisp.org>
Thu, 10 Jan 2008 01:36:58 +0000 (02:36 +0100)
ChangeLog
modules/wcwidth-tests
tests/test-wcwidth.c

index 60dd976..bc68f9d 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2008-01-09  Bruno Haible  <bruno@clisp.org>
+
+       * tests/test-wcwidth.c: Include <string.h> and localcharset.h.
+       (main): Don't perform the tests if setlocale did not install a UTF-8
+       locale. Needed on OpenBSD 4.0.
+       * modules/wcwidth-tests (Depends-on): Add localcharset.
+
 2008-01-09  Paul Eggert  <eggert@cs.ucla.edu>
 
        gl_FUNC_ALLOCA no longer defines HAVE_ALLOCA_H unconditionally.
index 91ae1b5..956072f 100644 (file)
@@ -2,6 +2,7 @@ Files:
 tests/test-wcwidth.c
 
 Depends-on:
+localcharset
 
 configure.ac:
 
index fe1094f..5b4affe 100644 (file)
@@ -23,6 +23,9 @@
 #include <locale.h>
 #include <stdio.h>
 #include <stdlib.h>
+#include <string.h>
+
+#include "localcharset.h"
 
 #define ASSERT(expr) \
   do                                                                        \
@@ -45,7 +48,13 @@ main ()
     ASSERT (wcwidth (wc) == 1);
 
   /* Switch to an UTF-8 locale.  */
-  if (setlocale (LC_ALL, "fr_FR.UTF-8") != NULL)
+  if (setlocale (LC_ALL, "fr_FR.UTF-8") != NULL
+      /* Check whether it's really an UTF-8 locale.
+        On OpenBSD 4.0, the setlocale call succeeds only for the LC_CTYPE
+        category and therefore returns "C/fr_FR.UTF-8/C/C/C/C", but the
+        LC_CTYPE category is effectively set to an ASCII LC_CTYPE category;
+        in particular, locale_charset() returns "ASCII".  */
+      && strcmp (locale_charset (), "UTF-8") == 0)
     {
       /* Test width of ASCII characters.  */
       for (wc = 0x20; wc < 0x7F; wc++)