aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>2003-10-31 23:35:42 +0000
committerRoland McGrath <roland@gnu.org>2003-10-31 23:35:42 +0000
commit158a85bff125c238ba67467f4a2416a9b3a6a824 (patch)
tree10124f757f24ea2425ce3dba76bbff35743945d6 /localedata
parent2003-10-31 Roland McGrath <roland@redhat.com> (diff)
downloadglibc-158a85bff125c238ba67467f4a2416a9b3a6a824.tar.gz
glibc-158a85bff125c238ba67467f4a2416a9b3a6a824.tar.bz2
glibc-158a85bff125c238ba67467f4a2416a9b3a6a824.zip
* locale/lc-ctype.c (_nl_postload_ctype): Update _nl_global_locale's
special members.
Diffstat (limited to 'localedata')
-rw-r--r--localedata/ChangeLog5
-rw-r--r--localedata/Makefile2
-rw-r--r--localedata/bug-usesetlocale.c38
3 files changed, 44 insertions, 1 deletions
diff --git a/localedata/ChangeLog b/localedata/ChangeLog
index b7285d1597..c572633003 100644
--- a/localedata/ChangeLog
+++ b/localedata/ChangeLog
@@ -1,3 +1,8 @@
+2003-10-31 Roland McGrath <roland@redhat.com>
+
+ * bug-usesetlocale.c: New file.
+ * Makefile (tests): Add it.
+
2003-10-01 Ulrich Drepper <drepper@redhat.com>
* SUPPORTED (SUPPORTED-LOCALES): Add uz_UZ@cyrillic.UTF-8.
diff --git a/localedata/Makefile b/localedata/Makefile
index c5e8711ca4..41495c24f6 100644
--- a/localedata/Makefile
+++ b/localedata/Makefile
@@ -92,7 +92,7 @@ locale_test_suite := tst_iswalnum tst_iswalpha tst_iswcntrl \
tst_wctype tst_wcwidth
tests = $(locale_test_suite) tst-digits tst-setlocale bug-iconv-trans \
- tst-leaks tst-mbswcs6 tst-xlocale1 tst-xlocale2
+ tst-leaks tst-mbswcs6 tst-xlocale1 tst-xlocale2 bug-usesetlocale
ifeq (yes,$(build-shared))
ifneq (no,$(PERL))
tests: $(objpfx)mtrace-tst-leaks
diff --git a/localedata/bug-usesetlocale.c b/localedata/bug-usesetlocale.c
new file mode 100644
index 0000000000..0637067de7
--- /dev/null
+++ b/localedata/bug-usesetlocale.c
@@ -0,0 +1,38 @@
+/* Test case for setlocale vs uselocale (LC_GLOBAL_LOCALE) bug. */
+
+#define _GNU_SOURCE 1
+#include <locale.h>
+#include <stdio.h>
+#include <ctype.h>
+
+static int
+do_test (void)
+{
+ __locale_t loc_new, loc_old;
+
+ int first = !!isalpha(0xE4);
+
+ setlocale (LC_ALL, "de_DE");
+
+ int global_de = !!isalpha(0xE4);
+
+ loc_new = newlocale (1 << LC_ALL, "C", 0);
+ loc_old = uselocale (loc_new);
+
+ int used_c = !!isalpha(0xE4);
+
+ uselocale (loc_old);
+
+ int used_global = !!isalpha(0xE4);
+
+ printf ("started %d, after setlocale %d\n", first, global_de);
+ printf ("after uselocale %d, after LC_GLOBAL_LOCALE %d\n",
+ used_c, used_global);
+
+ freelocale (loc_new);
+ return !(used_c == first && used_global == global_de);
+}
+
+
+#define TEST_FUNCTION do_test ()
+#include "test-skeleton.c"