]> git.ipfire.org Git - thirdparty/gettext.git/commitdiff
Avoid unsupported locales on OpenBSD.
authorBruno Haible <bruno@clisp.org>
Sun, 13 Jan 2008 16:55:25 +0000 (16:55 +0000)
committerBruno Haible <bruno@clisp.org>
Tue, 23 Jun 2009 10:15:36 +0000 (12:15 +0200)
gettext-tools/m4/locale-ja.m4

index d9a36c7f81ae546305e37e83d6208294158d448a..35e1c04fc39edbea8fa5d196df9a02b1616922d8 100644 (file)
@@ -1,5 +1,5 @@
-# locale-ja.m4 serial 3 (gettext-0.17)
-dnl Copyright (C) 2003, 2005-2007 Free Software Foundation, Inc.
+# locale-ja.m4 serial 4 (gettext-0.18)
+dnl Copyright (C) 2003, 2005-2008 Free Software Foundation, Inc.
 dnl This file is free software; the Free Software Foundation
 dnl gives unlimited permission to copy and/or distribute it,
 dnl with or without modifications, as long as this notice is preserved.
@@ -46,11 +46,18 @@ int main ()
   const char *p;
   /* Check whether the given locale name is recognized by the system.  */
   if (setlocale (LC_ALL, "") == NULL) return 1;
-  /* Check whether nl_langinfo(CODESET) is nonempty.
+  /* Check whether nl_langinfo(CODESET) is nonempty and not "ASCII" or "646".
      On MacOS X 10.3.5 (Darwin 7.5) in the fr_FR locale, nl_langinfo(CODESET)
-     is empty, and the behaviour of Tcl 8.4 in this locale is not useful.  */
+     is empty, and the behaviour of Tcl 8.4 in this locale is not useful.
+     On OpenBSD 4.0, when an unsupported locale is specified, setlocale()
+     succeeds but then nl_langinfo(CODESET) is "646". In this situations,
+     some unit tests fail.  */
 #if HAVE_LANGINFO_CODESET
-  if (nl_langinfo (CODESET) [0] == '\0') return 1;
+  {
+    const char *cs = nl_langinfo (CODESET);
+    if (cs[0] == '\0' || strcmp (cs, "ASCII") == 0 || strcmp (cs, "646") == 0)
+      return 1;
+  }
 #endif
 #ifdef __CYGWIN__
   /* On Cygwin, avoid locale names without encoding suffix, because the