4
0
mirror of git://sourceware.org/git/newlib-cygwin.git synced 2025-02-18 15:09:32 +08:00

Cygwin: fully support KOI8-T codeset

Commit 89eb4bce152f was pretty half-hearted, missing
the codepage character type tables and wctomb/mbtowc
mappings.

Fixes: 89eb4bce152f ("Cygwin: support KOI8-T codeset")
Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
Corinna Vinschen 2023-02-25 13:19:27 +01:00
parent 98aed7943e
commit 2b052b3c50
4 changed files with 51 additions and 7 deletions

View File

@ -469,13 +469,31 @@
_L, _L, _L, _L, _L, _L, _L, _L, \
_L, _L, _L, _L, _L, _L, _L
#define _CTYPE_PT154_255 _L
#define _CTYPE_CP103_128_254 \
_L, _L, _P, _U, _P, _P, _P, _P, \
0, _P, _L, _P, _U, _L, _U, 0, \
_U, _P, _P, _P, _P, _P, _P, _P, \
0, _P, 0, _P, 0, 0, 0, 0, \
0, _L, _U, _L, _P, _L, _P, _P, \
0, 0, 0, _P, _P, _P, _P, 0, \
_P, _P, _P, _U, 0, _U, _P, _P, \
0, _P, 0, _P, 0, 0, 0, _P, \
_L, _L, _L, _L, _L, _L, _L, _L, \
_L, _L, _L, _L, _L, _L, _L, _L, \
_L, _L, _L, _L, _L, _L, _L, _L, \
_L, _L, _L, _L, _L, _L, _L, _L, \
_U, _U, _U, _U, _U, _U, _U, _U, \
_U, _U, _U, _U, _U, _U, _U, _U, \
_U, _U, _U, _U, _U, _U, _U, _U, \
_U, _U, _U, _U, _U, _U, _U
#define _CTYPE_CP103_255 _U
#if defined(ALLOW_NEGATIVE_CTYPE_INDEX)
#ifndef __CYGWIN__
static const
#endif
char __ctype_cp[26][128 + 256] = {
char __ctype_cp[27][128 + 256] = {
{ _CTYPE_CP437_128_254,
0,
_CTYPE_DATA_0_127,
@ -632,11 +650,17 @@ char __ctype_cp[26][128 + 256] = {
_CTYPE_PT154_128_254,
_CTYPE_PT154_255
},
{ _CTYPE_CP103_128_254,
0,
_CTYPE_DATA_0_127,
_CTYPE_CP103_128_254,
_CTYPE_CP103_255
},
};
#else /* !defined(ALLOW_NEGATIVE_CTYPE_INDEX) */
static const char __ctype_cp[26][1 + 256] = {
static const char __ctype_cp[27][1 + 256] = {
{ 0,
_CTYPE_DATA_0_127,
_CTYPE_CP437_128_254,
@ -767,6 +791,11 @@ static const char __ctype_cp[26][1 + 256] = {
_CTYPE_PT154_128_254,
_CTYPE_PT154_255
},
{ 0,
_CTYPE_DATA_0_127,
_CTYPE_CP103_128_254,
_CTYPE_CP103_255
},
};
#endif /* ALLOW_NEGATIVE_CTYPE_INDEX */

View File

@ -487,7 +487,14 @@ __cp_102_mbtowc (struct _reent *r, wchar_t *pwc, const char *s, size_t n,
return ___cp_mbtowc (r, pwc, s, n, 25, state);
}
static mbtowc_p __cp_xxx_mbtowc[26] = {
static int
__cp_103_mbtowc (struct _reent *r, wchar_t *pwc, const char *s, size_t n,
mbstate_t *state)
{
return ___cp_mbtowc (r, pwc, s, n, 26, state);
}
static mbtowc_p __cp_xxx_mbtowc[27] = {
__cp_437_mbtowc,
__cp_720_mbtowc,
__cp_737_mbtowc,
@ -513,7 +520,8 @@ static mbtowc_p __cp_xxx_mbtowc[26] = {
__cp_20866_mbtowc,
__cp_21866_mbtowc,
__cp_101_mbtowc,
__cp_102_mbtowc
__cp_102_mbtowc,
__cp_103_mbtowc,
};
/* val *MUST* be valid! All checks for validity are supposed to be

View File

@ -611,7 +611,13 @@ __cp_102_wctomb (struct _reent *r, char *s, wchar_t _wchar, mbstate_t *state)
return ___cp_wctomb (r, s, _wchar, 25, state);
}
static wctomb_p __cp_xxx_wctomb[26] = {
static int
__cp_103_wctomb (struct _reent *r, char *s, wchar_t _wchar, mbstate_t *state)
{
return ___cp_wctomb (r, s, _wchar, 26, state);
}
static wctomb_p __cp_xxx_wctomb[27] = {
__cp_437_wctomb,
__cp_720_wctomb,
__cp_737_wctomb,
@ -637,7 +643,8 @@ static wctomb_p __cp_xxx_wctomb[26] = {
__cp_20866_wctomb,
__cp_21866_wctomb,
__cp_101_wctomb,
__cp_102_wctomb
__cp_102_wctomb,
__cp_103_wctomb,
};
/* val *MUST* be valid! All checks for validity are supposed to be

View File

@ -16,7 +16,7 @@ extern char _ctype_b[128 + 256];
time-critical anyway. */
extern int __iso_8859_index (const char *charset_ext); /* Newlib */
extern int __cp_index (const char *charset_ext); /* Newlib */
extern const char __ctype_cp[22][128 + 256]; /* Newlib */
extern const char __ctype_cp[27][128 + 256]; /* Newlib */
extern const char __ctype_iso[15][128 + 256]; /* Newlib */
void