Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2023-02-25 15:19:27 +0300
committerCorinna Vinschen <corinna@vinschen.de>2023-02-25 18:12:51 +0300
commit2b052b3c5080c1b601129fcceda5f6537a442c87 (patch)
tree7886ef6b384da1d04ee41dcd0347ad76ee1c8d8d /newlib/libc/stdlib
parent98aed7943ee3000281b1226e5a68152a3da7358f (diff)
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>
Diffstat (limited to 'newlib/libc/stdlib')
-rw-r--r--newlib/libc/stdlib/mbtowc_r.c12
-rw-r--r--newlib/libc/stdlib/wctomb_r.c11
2 files changed, 19 insertions, 4 deletions
diff --git a/newlib/libc/stdlib/mbtowc_r.c b/newlib/libc/stdlib/mbtowc_r.c
index ca876f9a0..01e596db8 100644
--- a/newlib/libc/stdlib/mbtowc_r.c
+++ b/newlib/libc/stdlib/mbtowc_r.c
@@ -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
diff --git a/newlib/libc/stdlib/wctomb_r.c b/newlib/libc/stdlib/wctomb_r.c
index a7f87cd9e..3081e9370 100644
--- a/newlib/libc/stdlib/wctomb_r.c
+++ b/newlib/libc/stdlib/wctomb_r.c
@@ -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