diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2016-07-20 22:05:59 +0200 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2016-08-15 10:56:57 +0200 |
commit | d16a56306d63b4d94412b479a8ea83463a3514ab (patch) | |
tree | b37c2954976f314628637e660e039f1be4034b1c /newlib/libc/stdlib/local.h | |
parent | 88208d3735821df0f5a66c5f8781282a7f5bf284 (diff) | |
download | cygnal-d16a56306d63b4d94412b479a8ea83463a3514ab.tar.gz cygnal-d16a56306d63b4d94412b479a8ea83463a3514ab.tar.bz2 cygnal-d16a56306d63b4d94412b479a8ea83463a3514ab.zip |
Consolidate wctomb/mbtowc calls for POSIX-1.2008
- Remove charset parameter from low level __foo_wctomb/__foo_mbtowc calls.
- Instead, create array of function for ISO and Windows codepages to point
to function which does not require to evaluate the charset string on
each call. Create matching helper functions. I.e., __iso_wctomb,
__iso_mbtowc, __cp_wctomb and __cp_mbtowc are functions returning the
right function pointer now.
- Create __WCTOMB/__MBTOWC macros utilizing per-reent locale and replace
calls to __wctomb/__mbtowc with calls to __WCTOMB/__MBTOWC.
- Drop global __wctomb/__mbtowc vars.
- Utilize aforementioned changes in Cygwin to get rid of charset in other,
calling functions and simplify the code.
- In Cygwin restrict global cygheap locale info to the job performed
by internal_setlocale. Use UTF-8 instead of ASCII on the fly in
internal conversion functions.
- In Cygwin dll_entry, make sure to initialize a TLS area with a NULL
_REENT->_locale pointer. Add comment to explain why.
Signed-off by: Corinna Vinschen <corinna@vinschen.de>
Diffstat (limited to 'newlib/libc/stdlib/local.h')
-rw-r--r-- | newlib/libc/stdlib/local.h | 71 |
1 files changed, 34 insertions, 37 deletions
diff --git a/newlib/libc/stdlib/local.h b/newlib/libc/stdlib/local.h index aaa32dff5..0b950d2f4 100644 --- a/newlib/libc/stdlib/local.h +++ b/newlib/libc/stdlib/local.h @@ -5,62 +5,59 @@ char * _EXFUN(_gcvt,(struct _reent *, double , int , char *, char, int)); -char *__locale_charset(_NOARGS); +#include "../locale/setlocale.h" #ifndef __machine_mbstate_t_defined #include <wchar.h> #endif -extern int (*__wctomb) (struct _reent *, char *, wchar_t, const char *, - mbstate_t *); -int __ascii_wctomb (struct _reent *, char *, wchar_t, const char *, - mbstate_t *); +typedef int wctomb_f (struct _reent *, char *, wchar_t, mbstate_t *); +typedef wctomb_f *wctomb_p; + +wctomb_f __ascii_wctomb; #ifdef _MB_CAPABLE -int __utf8_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); -int __sjis_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); -int __eucjp_wctomb (struct _reent *, char *, wchar_t, const char *, - mbstate_t *); -int __jis_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); -int __iso_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); -int __cp_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); +wctomb_f __utf8_wctomb; +wctomb_f __sjis_wctomb; +wctomb_f __eucjp_wctomb; +wctomb_f __jis_wctomb; +wctomb_p __iso_wctomb (int val); +wctomb_p __cp_wctomb (int val); #ifdef __CYGWIN__ -int __gbk_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); -int __kr_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); -int __big5_wctomb (struct _reent *, char *, wchar_t, const char *, mbstate_t *); +wctomb_f __gbk_wctomb; +wctomb_f __kr_wctomb; +wctomb_f __big5_wctomb; #endif #endif -extern int (*__mbtowc) (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __ascii_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); +#define __WCTOMB (__get_current_locale ()->wctomb) + +typedef int mbtowc_f (struct _reent *, wchar_t *, const char *, size_t, + mbstate_t *); +typedef mbtowc_f *mbtowc_p; + +mbtowc_f __ascii_mbtowc; #ifdef _MB_CAPABLE -int __utf8_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __sjis_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __eucjp_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __jis_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __iso_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __cp_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); +mbtowc_f __utf8_mbtowc; +mbtowc_f __sjis_mbtowc; +mbtowc_f __eucjp_mbtowc; +mbtowc_f __jis_mbtowc; +mbtowc_p __iso_mbtowc (int val); +mbtowc_p __cp_mbtowc (int val); #ifdef __CYGWIN__ -int __gbk_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __kr_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); -int __big5_mbtowc (struct _reent *, wchar_t *, const char *, size_t, - const char *, mbstate_t *); +mbtowc_f __gbk_mbtowc; +mbtowc_f __kr_mbtowc; +mbtowc_f __big5_mbtowc; #endif #endif +#define __MBTOWC (__get_current_locale ()->mbtowc) + extern wchar_t __iso_8859_conv[14][0x60]; +int __iso_8859_val_index (int); int __iso_8859_index (const char *); extern wchar_t __cp_conv[][0x80]; +int __cp_val_index (int); int __cp_index (const char *); #endif |