diff options
author | Manuel Novoa III <mjn3@codepoet.org> | 2003-08-24 03:49:13 +0000 |
---|---|---|
committer | Manuel Novoa III <mjn3@codepoet.org> | 2003-08-24 03:49:13 +0000 |
commit | 50660812be5588036a14fc85af16bccef68fac02 (patch) | |
tree | 65f25cc1dda3c7efc76efee2c61b28973465db2a | |
parent | 02f74937667727e32c591afe42e90e2b515ab61e (diff) |
Fix a few bugs in the new extended locale functions.
Move stub gettext functions to a stub libintl to make switching in
gnu gettext easier. Also add a few gnu-isms.
Change to using hidden names with global weak aliases for the extended
locale functions, as expected by libstd++.
Slightly rework the locale data generation stuff to allow pregenerated
locale data to be used with buildroot.
-rw-r--r-- | Makefile | 3 | ||||
-rw-r--r-- | extra/locale/Makefile | 42 | ||||
-rw-r--r-- | include/langinfo.h | 2 | ||||
-rw-r--r-- | include/locale.h | 6 | ||||
-rw-r--r-- | include/stdlib.h | 31 | ||||
-rw-r--r-- | include/string.h | 11 | ||||
-rw-r--r-- | include/time.h | 11 | ||||
-rw-r--r-- | include/wchar.h | 39 | ||||
-rw-r--r-- | include/wctype.h | 17 | ||||
-rw-r--r-- | libc/misc/ctype/ctype.c | 14 | ||||
-rw-r--r-- | libc/misc/gnu/obstack.c | 2 | ||||
-rw-r--r-- | libc/misc/intl/Makefile | 3 | ||||
-rw-r--r-- | libc/misc/intl/intl.c | 106 | ||||
-rw-r--r-- | libc/misc/locale/.cvsignore | 1 | ||||
-rw-r--r-- | libc/misc/locale/Makefile | 22 | ||||
-rw-r--r-- | libc/misc/locale/locale.c | 71 | ||||
-rw-r--r-- | libc/misc/time/time.c | 8 | ||||
-rw-r--r-- | libc/misc/wctype/wctype.c | 9 | ||||
-rw-r--r-- | libc/stdlib/stdlib.c | 48 | ||||
-rw-r--r-- | libc/stdlib/strtod.c | 31 | ||||
-rw-r--r-- | libc/string/wstring.c | 32 | ||||
-rw-r--r-- | libc/sysdeps/linux/common/bits/uClibc_locale.h | 11 | ||||
-rw-r--r-- | libintl/.cvsignore | 1 | ||||
-rw-r--r-- | libintl/Makefile | 66 | ||||
-rw-r--r-- | libintl/intl.c | 166 |
25 files changed, 521 insertions, 232 deletions
@@ -32,7 +32,7 @@ noconfig_targets := menuconfig config oldconfig randconfig \ TOPDIR=./ include Rules.mak -DIRS = extra ldso libc libcrypt libresolv libnsl libutil libm libpthread +DIRS = extra ldso libc libcrypt libresolv libnsl libutil libm libpthread libintl ifeq ($(strip $(HAVE_DOT_CONFIG)),y) @@ -52,6 +52,7 @@ ifeq ($(strip $(HAVE_SHARED)),y) @$(MAKE) -C libutil shared @$(MAKE) -C libm shared @$(MAKE) -C libpthread shared + @$(MAKE) -C libintl shared else ifeq ($(SHARED_TARGET),) @echo diff --git a/extra/locale/Makefile b/extra/locale/Makefile index 51fcde85b..f2ea39ee0 100644 --- a/extra/locale/Makefile +++ b/extra/locale/Makefile @@ -41,7 +41,6 @@ wctables.h: gen_wctype gen_locale: gen_locale.c c8tables.h $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) gen_locale.c -o $@ -# TODO: if no wide char support, we should auto-disable all UTF-8 locales locale_tables.h: gen_locale locales.txt ./gen_locale locales.txt @@ -70,62 +69,27 @@ locales.txt: false; \ fi; -# ifneq ($(TARGET_ARCH),$(HOST_ARCH)) - -# locale.mmap: gen_mmap -# echo Your locale.mmap file is either missing or out of date. -# echo The developmental code can only generate one for the -# echo target arch == native arch case. Sorry. -# else - -# gen_mmap: gen_mmap.c c8tables.h wctables.h locale_tables.h -# gcc $(CFLAGS_mmap) -Os -Wall -static gen_mmap.c -o gen_mmap - -# locale.mmap: gen_mmap -# ./gen_mmap - -# endif - -# lmmtolso: lmmtolso.c -# gcc -Os -Wall lmmtolso.c -o lmmtolso - -# locale_data.c: lmmtolso locale.mmap -# ./lmmtolso - gen_ldc: gen_ldc.c c8tables.h wctables.h locale_tables.h locale_collate.h $(HOSTCC) $(HOSTCFLAGS) $(NATIVE_LDFLAGS) $(CFLAGS_mmap) gen_ldc.c -o $@ -#gen_ldc.c -o gen_ldc locale_data.c: gen_ldc ./gen_ldc -locale_data.o: locale_data.c lt_defines.h - $(CC) $(CFLAGS_mmap) -c locale_data.c - $(STRIPTOOL) -x -R .note -R .comment locale_data.o - uClibc_locale_data.h: c8tables.h wctables.h lt_defines.h locale_mmap.h grep -v "define __LC" lt_defines.h > uClibc_locale_data.h cat c8tables.h wctables.h locale_mmap.h >> uClibc_locale_data.h -links-target: locale_data.o uClibc_locale_data.h - ln -sf ../../../extra/locale/locale_data.o ../../libc/misc/locale +links-target: locale_data.c uClibc_locale_data.h cat uClibc_locale_data.h | awk 'BEGIN{i=1}{ if ( /WANT_/ ) i = /endif/ ; else if (i) print $0 }' > ../../include/bits/uClibc_locale_data.h -# cp uClibc_locale_data.h ../../libc/sysdeps/linux/common/bits/ - pregen: - $(CC) $(CFLAGS_mmap) -c locale_data.c - $(STRIPTOOL) -x -R .note -R .comment locale_data.o - ln -sf ../../../extra/locale/locale_data.o ../../libc/misc/locale cat uClibc_locale_data.h | awk 'BEGIN{i=1}{ if ( /WANT_/ ) i = /endif/ ; else if (i) print $0 }' > ../../include/bits/uClibc_locale_data.h -# cp uClibc_locale_data.h ../../libc/sysdeps/linux/common/bits/ - clean: rm -f *.[oa] *~ core rm -f gen_wc8bit gen_wctype gen_locale gen_ldc gen_collate rm -f c8tables.h wctables.h locale_tables.h lt_defines.h locale_collate.h rm -f gen_mmap locale.mmap lmmtolso - rm -f locale_data.c locale_data.o uClibc_locale_data.h + rm -f locale_data.c uClibc_locale_data.h -.PHONY: pregen +.PHONY: pregen links-target diff --git a/include/langinfo.h b/include/langinfo.h index a129c12ae..1852b99b0 100644 --- a/include/langinfo.h +++ b/include/langinfo.h @@ -615,6 +615,8 @@ extern char *nl_langinfo (nl_item __item) __THROW; /* Just like nl_langinfo but get the information from the locale object L. */ extern char *nl_langinfo_l (nl_item __item, __locale_t l); +extern char *__nl_langinfo_l (nl_item __item, __locale_t l); + #endif #endif diff --git a/include/locale.h b/include/locale.h index 02d33a0d4..d7f90c969 100644 --- a/include/locale.h +++ b/include/locale.h @@ -218,6 +218,12 @@ extern __locale_t uselocale (__locale_t __dataset) __THROW; Passing this value to any other function has undefined behavior. */ # define LC_GLOBAL_LOCALE ((__locale_t) -1L) +extern __locale_t __newlocale (int __category_mask, __const char *__locale, + __locale_t __base) __THROW; +extern __locale_t __duplocale (__locale_t __dataset) __THROW; +extern void __freelocale (__locale_t __dataset) __THROW; +extern __locale_t __uselocale (__locale_t __dataset) __THROW; + #endif __END_DECLS diff --git a/include/stdlib.h b/include/stdlib.h index f7589d7ea..82f1643b6 100644 --- a/include/stdlib.h +++ b/include/stdlib.h @@ -267,6 +267,37 @@ extern float strtof_l (__const char *__restrict __nptr, extern long double strtold_l (__const char *__restrict __nptr, char **__restrict __endptr, __locale_t __loc) __THROW; + +/* Internal names to support libstd++. */ +extern long int __strtol_l (__const char *__restrict __nptr, + char **__restrict __endptr, int __base, + __locale_t __loc) __THROW; + +extern unsigned long int __strtoul_l (__const char *__restrict __nptr, + char **__restrict __endptr, + int __base, __locale_t __loc) __THROW; + +__extension__ +extern long long int __strtoll_l (__const char *__restrict __nptr, + char **__restrict __endptr, int __base, + __locale_t __loc) __THROW; + +__extension__ +extern unsigned long long int __strtoull_l (__const char *__restrict __nptr, + char **__restrict __endptr, + int __base, __locale_t __loc) + __THROW; + +extern double __strtod_l (__const char *__restrict __nptr, + char **__restrict __endptr, __locale_t __loc) + __THROW; + +extern float __strtof_l (__const char *__restrict __nptr, + char **__restrict __endptr, __locale_t __loc) __THROW; + +extern long double __strtold_l (__const char *__restrict __nptr, + char **__restrict __endptr, + __locale_t __loc) __THROW; #endif /* GNU */ #endif /* __UCLIBC_HAS_XLOCALE__ */ diff --git a/include/string.h b/include/string.h index f3ef812bf..a2045eeda 100644 --- a/include/string.h +++ b/include/string.h @@ -117,9 +117,15 @@ __END_NAMESPACE_STD /* Compare the collated forms of S1 and S2 using rules from L. */ extern int strcoll_l (__const char *__s1, __const char *__s2, __locale_t __l) __THROW __attribute_pure__; +extern int __strcoll_l (__const char *__s1, __const char *__s2, __locale_t __l) + __THROW __attribute_pure__; + /* Put a transformation of SRC into no more than N bytes of DEST. */ extern size_t strxfrm_l (char *__dest, __const char *__src, size_t __n, __locale_t __l) __THROW; +extern size_t __strxfrm_l (char *__dest, __const char *__src, size_t __n, + __locale_t __l) __THROW; + #endif #endif @@ -323,10 +329,15 @@ extern int strncasecmp (__const char *__s1, __const char *__s2, size_t __n) of the global one. */ extern int strcasecmp_l (__const char *__s1, __const char *__s2, __locale_t __loc) __THROW __attribute_pure__; +extern int __strcasecmp_l (__const char *__s1, __const char *__s2, + __locale_t __loc) __THROW __attribute_pure__; extern int strncasecmp_l (__const char *__s1, __const char *__s2, size_t __n, __locale_t __loc) __THROW __attribute_pure__; +extern int __strncasecmp_l (__const char *__s1, __const char *__s2, + size_t __n, __locale_t __loc) + __THROW __attribute_pure__; #endif #endif diff --git a/include/time.h b/include/time.h index 8dc787917..d2ae86328 100644 --- a/include/time.h +++ b/include/time.h @@ -224,6 +224,17 @@ extern size_t strftime_l (char *__restrict __s, size_t __maxsize, extern char *strptime_l (__const char *__restrict __s, __const char *__restrict __fmt, struct tm *__tp, __locale_t __loc) __THROW; + + +extern size_t __strftime_l (char *__restrict __s, size_t __maxsize, + __const char *__restrict __format, + __const struct tm *__restrict __tp, + __locale_t __loc) __THROW; + +extern char *__strptime_l (__const char *__restrict __s, + __const char *__restrict __fmt, struct tm *__tp, + __locale_t __loc) __THROW; + # endif #endif diff --git a/include/wchar.h b/include/wchar.h index 5fb44f418..09ab741ae 100644 --- a/include/wchar.h +++ b/include/wchar.h @@ -180,9 +180,13 @@ extern int wcsncasecmp (__const wchar_t *__s1, __const wchar_t *__s2, extern int wcscasecmp_l (__const wchar_t *__s1, __const wchar_t *__s2, __locale_t __loc) __THROW; +extern int __wcscasecmp_l (__const wchar_t *__s1, __const wchar_t *__s2, + __locale_t __loc) __THROW; extern int wcsncasecmp_l (__const wchar_t *__s1, __const wchar_t *__s2, size_t __n, __locale_t __loc) __THROW; +extern int __wcsncasecmp_l (__const wchar_t *__s1, __const wchar_t *__s2, + size_t __n, __locale_t __loc) __THROW; #endif /* __UCLIBC_HAS_XLOCALE__ */ #endif @@ -206,12 +210,17 @@ __END_NAMESPACE_C99 LC_COLLATE category of the given locale. */ extern int wcscoll_l (__const wchar_t *__s1, __const wchar_t *__s2, __locale_t __loc) __THROW; +extern int __wcscoll_l (__const wchar_t *__s1, __const wchar_t *__s2, + __locale_t __loc) __THROW; /* Transform S2 into array pointed to by S1 such that if wcscmp is applied to two transformed strings the result is the as applying `wcscoll' to the original strings. */ extern size_t wcsxfrm_l (wchar_t *__s1, __const wchar_t *__s2, size_t __n, __locale_t __loc) __THROW; +extern size_t __wcsxfrm_l (wchar_t *__s1, __const wchar_t *__s2, + size_t __n, __locale_t __loc) __THROW; + #endif /* __UCLIBC_HAS_XLOCALE__ */ /* Duplicate S, returning an identical malloc'd string. */ @@ -465,33 +474,57 @@ extern unsigned long long int wcstouq (__const wchar_t *__restrict __nptr, extern long int wcstol_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, int __base, __locale_t __loc) __THROW; +extern long int __wcstol_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, int __base, + __locale_t __loc) __THROW; extern unsigned long int wcstoul_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, int __base, __locale_t __loc) __THROW; +extern unsigned long int __wcstoul_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, + int __base, __locale_t __loc) __THROW; __extension__ extern long long int wcstoll_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, int __base, __locale_t __loc) __THROW; +__extension__ +extern long long int __wcstoll_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, + int __base, __locale_t __loc) __THROW; __extension__ extern unsigned long long int wcstoull_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, int __base, __locale_t __loc) __THROW; +__extension__ +extern unsigned long long int __wcstoull_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, + int __base, __locale_t __loc) + __THROW; extern double wcstod_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, __locale_t __loc) __THROW; +extern double __wcstod_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, __locale_t __loc) + __THROW; extern float wcstof_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, __locale_t __loc) __THROW; +extern float __wcstof_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, __locale_t __loc) + __THROW; extern long double wcstold_l (__const wchar_t *__restrict __nptr, wchar_t **__restrict __endptr, __locale_t __loc) __THROW; +extern long double __wcstold_l (__const wchar_t *__restrict __nptr, + wchar_t **__restrict __endptr, + __locale_t __loc) __THROW; #endif /* __UCLIBC_HAS_XLOCALE__ */ #endif /* GNU */ @@ -803,6 +836,7 @@ extern int fputws_unlocked (__const wchar_t *__restrict __ws, #endif +#if 0 __BEGIN_NAMESPACE_C99 /* Format TP into S according to FORMAT. Write no more than MAXSIZE wide characters and return the number @@ -822,8 +856,13 @@ extern size_t wcsftime_l (wchar_t *__restrict __s, size_t __maxsize, __const wchar_t *__restrict __format, __const struct tm *__restrict __tp, __locale_t __loc) __THROW; +extern size_t __wcsftime_l (wchar_t *__restrict __s, size_t __maxsize, + __const wchar_t *__restrict __format, + __const struct tm *__restrict __tp, + __locale_t __loc) __THROW; #endif /* __UCLIBC_HAS_XLOCALE__ */ # endif +#endif /* 0 */ /* The X/Open standard demands that most of the functions defined in the <wctype.h> header must also appear here. This is probably diff --git a/include/wctype.h b/include/wctype.h index 86b5db44c..688c1fd46 100644 --- a/include/wctype.h +++ b/include/wctype.h @@ -322,6 +322,23 @@ extern wctrans_t wctrans_l (__const char *__property, __locale_t __locale) extern wint_t towctrans_l (wint_t __wc, wctrans_t __desc, __locale_t __locale) __THROW; +extern int __iswalnum_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswalpha_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswblank_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswcntrl_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswdigit_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswgraph_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswlower_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswprint_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswpunct_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswspace_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswupper_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswxdigit_l(wint_t __wc, __locale_t __locale) __THROW; +extern wint_t __towlower_l(wint_t __wc, __locale_t __locale) __THROW; +extern wint_t __towupper_l(wint_t __wc, __locale_t __locale) __THROW; +extern int __iswctype_l(wint_t __wc, wctype_t __desc, __locale_t __locale) __THROW; +extern wctrans_t __wctrans_l(const char *__property, __locale_t __locale) __THROW; +extern wint_t __towctrans_l(wint_t __wc, wctrans_t __desc, __locale_t __locale) __THROW; # endif /* Use GNU. */ __END_DECLS diff --git a/libc/misc/ctype/ctype.c b/libc/misc/ctype/ctype.c index 0eb97140d..a89e1e75c 100644 --- a/libc/misc/ctype/ctype.c +++ b/libc/misc/ctype/ctype.c @@ -256,8 +256,9 @@ int tolower(int c) #ifdef L_tolower_l #undef tolower_l +#undef __tolower_l -int tolower_l(int c, __locale_t l) +int __tolower_l(int c, __locale_t l) { #if defined(__UCLIBC_HAS_CTYPE_ENFORCED__) assert(CTYPE_DOMAIN_CHECK(c)); @@ -265,6 +266,8 @@ int tolower_l(int c, __locale_t l) return __UCLIBC_CTYPE_IN_TO_DOMAIN(c) ? l->__ctype_tolower[c] : c; } +weak_alias(__tolower_l, tolower_l) + #endif /**********************************************************************/ #ifdef L_toupper @@ -282,8 +285,9 @@ int toupper(int c) #ifdef L_toupper_l #undef toupper_l +#undef __toupper_l -int toupper_l(int c, __locale_t l) +int __toupper_l(int c, __locale_t l) { #if defined(__UCLIBC_HAS_CTYPE_ENFORCED__) assert(CTYPE_DOMAIN_CHECK(c)); @@ -291,6 +295,8 @@ int toupper_l(int c, __locale_t l) return __UCLIBC_CTYPE_IN_TO_DOMAIN(c) ? l->__ctype_toupper[c] : c; } +weak_alias(__toupper_l, toupper_l) + #endif /**********************************************************************/ #if defined(L_isascii) || defined(L_isascii_l) @@ -300,6 +306,8 @@ int __XL(isascii)(int c) return __isascii(c); /* locale-independent */ } +__XL_ALIAS(isascii) + #endif /**********************************************************************/ #if defined(L_toascii) || defined(L_toascii_l) @@ -309,6 +317,8 @@ int __XL(toascii)(int c) return __toascii(c); /* locale-independent */ } +__XL_ALIAS(toascii) + #endif /**********************************************************************/ /* old uClibc extensions */ diff --git a/libc/misc/gnu/obstack.c b/libc/misc/gnu/obstack.c index 87b294c25..a3f7f3f45 100644 --- a/libc/misc/gnu/obstack.c +++ b/libc/misc/gnu/obstack.c @@ -466,7 +466,7 @@ _obstack_memory_used (h) # if (HAVE_LIBINTL_H && ENABLE_NLS) || defined _LIBC # include <libintl.h> # ifndef _ -# define _(Str) gettext (Str) +# define _(Str) __dcgettext (NULL, Str, LC_MESSAGES) # endif # else # define _(Str) (Str) diff --git a/libc/misc/intl/Makefile b/libc/misc/intl/Makefile index 75fbb321f..9975e5eb1 100644 --- a/libc/misc/intl/Makefile +++ b/libc/misc/intl/Makefile @@ -25,8 +25,7 @@ TOPDIR=../../../ include $(TOPDIR)Rules.mak MSRC= intl.c -MOBJ= gettext.o ngettext.o dgettext.o dcgettext.o dngettext.o dcngettext.o \ - textdomain.o bindtextdomain.o bind_textdomain_codeset.o +MOBJ= __uClibc_dgettext.o __uClibc_dcgettext.o OBJS=$(MOBJ) diff --git a/libc/misc/intl/intl.c b/libc/misc/intl/intl.c index 183ffcc92..eca6fa96a 100644 --- a/libc/misc/intl/intl.c +++ b/libc/misc/intl/intl.c @@ -16,7 +16,7 @@ */ /* - * Supply some weaks for gettext and friends. Used by strerror*(). + * Supply some weaks for use by strerror*(), etc. */ #include <stdlib.h> @@ -27,123 +27,27 @@ #include <libintl.h> /**********************************************************************/ -#ifdef L_gettext - -char *weak_function gettext(const char *msgid) -{ - return (char *) msgid; -} - -#endif -/**********************************************************************/ -#ifdef L_dgettext +#ifdef L___uClibc_dgettext char *__uClibc_dgettext(const char *domainname, - const char *msgid) + const char *msgid) { return (char *) msgid; } weak_alias (__uClibc_dgettext, __dgettext) -weak_alias (__uClibc_dgettext, dgettext) #endif /**********************************************************************/ -#ifdef L_dcgettext +#ifdef L___uClibc_dcgettext char * __uClibc_dcgettext(const char *domainname, - const char *msgid, int category) + const char *msgid, int category) { return (char *) msgid; } weak_alias (__uClibc_dcgettext, __dcgettext) -weak_alias (__uClibc_dcgettext, dcgettext) - -#endif -/**********************************************************************/ -#ifdef L_ngettext - -char *weak_function ngettext(const char *msgid1, const char *msgid2, - unsigned long int n) -{ - return (char *) ((n == 1) ? msgid1 : msgid2); -} - -#endif -/**********************************************************************/ -#ifdef L_dngettext - -char *weak_function dngettext(const char *domainname, const char *msgid1, - const char *msgid2, unsigned long int n) -{ - return (char *) ((n == 1) ? msgid1 : msgid2); -} - -#endif -/**********************************************************************/ -#ifdef L_dcngettext - -char *weak_function dcngettext(const char *domainname, const char *msgid1, - const char *msgid2, unsigned long int n, - int category) -{ - return (char *) ((n == 1) ? msgid1 : msgid2); -} - -#endif -/**********************************************************************/ -#ifdef L_textdomain - -char *weak_function textdomain(const char *domainname) -{ - static const char default_str[] = "messages"; - - if (domainname && *domainname && strcmp(domainname, default_str)) { - __set_errno(EINVAL); - return NULL; - } - return (char *) default_str; -} - -#endif -/**********************************************************************/ -#ifdef L_bindtextdomain - -char *weak_function bindtextdomain(const char *domainname, const char *dirname) -{ - static const char dir[] = "/"; - - if (!domainname || !*domainname - || (dirname -#if 1 - && ((dirname[0] != '/') || dirname[1]) -#else - && strcmp(dirname, dir) -#endif - ) - ) { - __set_errno(EINVAL); - return NULL; - } - - return (char *) dir; -} - -#endif -/**********************************************************************/ -#ifdef L_bind_textdomain_codeset - -/* Specify the character encoding in which the messages from the - DOMAINNAME message catalog will be returned. */ -char *weak_function bind_textdomain_codeset(const char *domainname, - const char *codeset) -{ - if (!domainname || !*domainname || codeset) { - __set_errno(EINVAL); - } - return NULL; -} #endif /**********************************************************************/ diff --git a/libc/misc/locale/.cvsignore b/libc/misc/locale/.cvsignore index 11e4e51bc..3209b4ee4 100644 --- a/libc/misc/locale/.cvsignore +++ b/libc/misc/locale/.cvsignore @@ -1 +1,2 @@ +locale_data.c locale_data.o diff --git a/libc/misc/locale/Makefile b/libc/misc/locale/Makefile index 8ad041e69..17b208b2e 100644 --- a/libc/misc/locale/Makefile +++ b/libc/misc/locale/Makefile @@ -36,18 +36,14 @@ ifeq ($(UCLIBC_HAS_XLOCALE),y) MOBJx += nl_langinfo_l.o duplocale.o freelocale.o uselocale.o __curlocale.o endif -OBJS= $(MOBJ) $(MOBJx) - -ifeq ($(UCLIBC_HAS_LOCALE),y) - OBJS += $(COBJS) locale_data.o -endif - DATA= ifeq ($(UCLIBC_HAS_LOCALE),y) - DATA += locale_data.o + DATA = locale_data.o endif -all: $(DATA) $(OBJS) $(LIBC) +OBJS= $(MOBJ) $(MOBJx) $(DATA) + +all: $(OBJS) $(LIBC) $(LIBC): ar-target @@ -63,12 +59,14 @@ $(MOBJx): $(MSRC) $(CC) $(CFLAGS) -DL_$* -D__UCLIBC_DO_XLOCALE $< -c -o $*.o $(STRIPTOOL) -x -R .note -R .comment $*.o -$(OBJS): Makefile +locale_data.o: + ln -sf ../../../extra/locale/locale_data.c + $(CC) $(CFLAGS) -c -D__WCHAR_ENABLED -I../../../extra/locale locale_data.c -o $@ + $(STRIPTOOL) -x -R .note -R .comment $*.o -# locale_data.o: -# make -C $(TOPDIR)/extra/locale +$(OBJS): Makefile clean: - rm -f *.[oa] *~ core + rm -f *.[oa] *~ core locale_data.c .PHONY: data diff --git a/libc/misc/locale/locale.c b/libc/misc/locale/locale.c index b101f6dad..8f0cbd415 100644 --- a/libc/misc/locale/locale.c +++ b/libc/misc/locale/locale.c @@ -16,7 +16,6 @@ */ /* Nov. 1, 2002 - * * Reworked setlocale() return values and locale arg processing to * be more like glibc. Applications expecting to be able to * query locale settings should now work... at the cost of almost @@ -24,8 +23,15 @@ * Fixed a bug in the internal fixed-size-string locale specifier code. * * Dec 20, 2002 - * * Added in collation support and updated stub nl_langinfo. + * + * Aug 1, 2003 + * Added glibc-like extended locale stuff (newlocale, duplocale, etc). + * + * Aug 18, 2003 + * Bug in duplocale... collation data wasn't copied. + * Bug in newlocale... translate 1<<LC_ALL to LC_ALL_MASK. + * Bug in _wchar_utf8sntowcs... fix cut-n-paste error. */ @@ -48,6 +54,8 @@ #include <assert.h> #include <errno.h> #include <ctype.h> +#warning devel code +#include <stdio.h> #undef __LOCALE_C_ONLY #ifndef __UCLIBC_HAS_LOCALE__ @@ -249,10 +257,8 @@ char *setlocale(int category, const char *locale) } if (locale != NULL) { /* Not just a query... */ - if (!__newlocale((category == LC_ALL) ? LC_ALL_MASK : (1 << category), - locale, __global_locale) - ) { /* Failed! */ - return NULL; + if (!__newlocale((1 << category), locale, __global_locale)) { + return NULL; /* Failed! */ } update_hr_locale(__global_locale->cur_locale); } @@ -436,35 +442,36 @@ static int init_cur_collate(int der_num, __collate_t *cur_collate) cur_collate->ti_mask = (1 << cur_collate->ti_shift)-1; cur_collate->ii_mask = (1 << cur_collate->ii_shift)-1; -/* printf("base=%d num_col_base: %d %d\n", cdd->base_idx ,cur_collate->num_col_base, cdb->num_col_base); */ +/* fflush(stdout); */ +/* fprintf(stderr,"base=%d num_col_base: %d %d\n", cdd->base_idx ,cur_collate->num_col_base, cdb->num_col_base); */ n = (sizeof(coldata_header_t) + cdh->num_base * sizeof(coldata_base_t) + cdh->num_der * sizeof(coldata_der_t))/2; -/* printf("n = %d\n", n); */ +/* fprintf(stderr,"n = %d\n", n); */ cur_collate->index2weight_tbl = __locale_collate_tbl + n + cdb->index2weight_offset; -/* printf("i2w = %d\n", n + cdb->index2weight_offset); */ +/* fprintf(stderr,"i2w = %d\n", n + cdb->index2weight_offset); */ n += cdh->num_index2weight; cur_collate->index2ruleidx_tbl = __locale_collate_tbl + n + cdb->index2ruleidx_offset; -/* printf("i2r = %d\n", n + cdb->index2ruleidx_offset); */ +/* fprintf(stderr,"i2r = %d\n", n + cdb->index2ruleidx_offset); */ n += cdh->num_index2ruleidx; cur_collate->multistart_tbl = __locale_collate_tbl + n + cdd->multistart_offset; -/* printf("mts = %d\n", n + cdb->multistart_offset); */ +/* fprintf(stderr,"mts = %d\n", n + cdb->multistart_offset); */ n += cdh->num_multistart; cur_collate->overrides_tbl = __locale_collate_tbl + n + cdd->overrides_offset; -/* printf("ovr = %d\n", n + cdd->overrides_offset); */ +/* fprintf(stderr,"ovr = %d\n", n + cdd->overrides_offset); */ n += cdh->num_override; cur_collate->ruletable = __locale_collate_tbl + n; -/* printf("rtb = %d\n", n); */ +/* fprintf(stderr, "rtb = %d\n", n); */ n += cdh->num_ruletable; cur_collate->weightstr = __locale_collate_tbl + n; -/* printf("wts = %d\n", n); */ +/* fprintf(stderr,"wts = %d\n", n); */ n += cdh->num_weightstr; cur_collate->wcs2colidt_tbl = __locale_collate_tbl + n + (((unsigned long)(cdb->wcs2colidt_offset_hi)) << 16) + cdb->wcs2colidt_offset_low; -/* printf("wcs = %lu\n", n + (((unsigned long)(cdb->wcs2colidt_offset_hi)) << 16) */ -/* + cdb->wcs2colidt_offset_low); */ +/* fprintf(stderr,"wcs = %lu\n", n + (((unsigned long)(cdb->wcs2colidt_offset_hi)) << 16) */ +/* + cdb->wcs2colidt_offset_low); */ cur_collate->MAX_WEIGHTS = cdh->MAX_WEIGHTS; @@ -494,13 +501,15 @@ static int init_cur_collate(int der_num, __collate_t *cur_collate) w = *p++; do { i = *p++; -/* fprintf(stderr, " i=%d w=%d *p=%d\n", i, w, *p); */ +/* fprintf(stderr, " i=%d (%#x) w=%d *p=%d\n", i, i, w, *p); */ cur_collate->index2weight[i-1] = w++; cur_collate->index2ruleidx[i-1] = *p++; } while (--n); } + assert(*p == 1); while (*++p) { i = *p; +/* fprintf(stderr, " i=%d (%#x) w=%d *p=%d\n", i, i, p[1], p[2]); */ cur_collate->index2weight[i-1] = *++p; cur_collate->index2ruleidx[i-1] = *++p; } @@ -869,7 +878,7 @@ char *nl_langinfo(nl_item item) char *nl_langinfo(nl_item item) { - return nl_langinfo_l(item, __UCLIBC_CURLOCALE); + return __nl_langinfo_l(item, __UCLIBC_CURLOCALE); } #else /* defined(__UCLIBC_HAS_XLOCALE__) && !defined(__UCLIBC_DO_XLOCALE) */ @@ -1056,6 +1065,10 @@ __locale_t __newlocale(int category_mask, const char *locale, __locale_t base) int i, j, k; unsigned char new_selector[LOCALE_SELECTOR_SIZE]; + if (category_mask == (1 << LC_ALL)) { + category_mask = LC_ALL_MASK; + } + if (!locale || (((unsigned int)(category_mask)) > LC_ALL_MASK)) { INVALID: __set_errno(EINVAL); @@ -1141,20 +1154,22 @@ weak_alias(__newlocale, newlocale) #warning REMINDER: When we allocate ctype tables, remember to dup them. #endif -__locale_t duplocale(__locale_t dataset) +__locale_t __duplocale(__locale_t dataset) { __locale_t r; uint16_t * i2w; + size_t n; assert(dataset != LC_GLOBAL_LOCALE); if ((r = malloc(sizeof(__uclibc_locale_t))) != NULL) { - if ((i2w = calloc(2*dataset->collate.max_col_index+2, - sizeof(uint16_t))) + n = 2*dataset->collate.max_col_index+2; + if ((i2w = calloc(n, sizeof(uint16_t))) != NULL ) { memcpy(r, dataset, sizeof(__uclibc_locale_t)); r->collate.index2weight = i2w; + memcpy(i2w, dataset->collate.index2weight, n * sizeof(uint16_t)); } else { free(r); |