summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--localedata/ChangeLog4
-rw-r--r--localedata/locales/ja_JP4
-rw-r--r--wcsmbs/mbsrtowcs.c14
4 files changed, 20 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index b14b44ebf4..1fe0314e24 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
2000-01-18 Ulrich Drepper <drepper@cygnus.com>
+ * wcsmbs/mbsrtowcs.c: Compute return value correctly after change
+ in gconv function.
+
* wcsmbs/mbrtowc.c: Don't set errno if byte sequence is only
incomplete but correct.
diff --git a/localedata/ChangeLog b/localedata/ChangeLog
index 637bba7f12..2433c38c6a 100644
--- a/localedata/ChangeLog
+++ b/localedata/ChangeLog
@@ -1,3 +1,7 @@
+2000-01-18 Ulrich Drepper <drepper@cygnus.com>
+
+ * locales/ja_JP: Add double-width digits to digit class.
+
2000-01-12 Ulrich Drepper <drepper@cygnus.com>
* charmaps/ISO-8859-16: Add mapping for /xba.
diff --git a/localedata/locales/ja_JP b/localedata/locales/ja_JP
index a7dbe82229..c5185cc04a 100644
--- a/localedata/locales/ja_JP
+++ b/localedata/locales/ja_JP
@@ -60,7 +60,9 @@ alpha <A>;<B>;<C>;<D>;<E>;<F>;<G>;<H>;<I>;<J>;<K>;<L>;<M>;/
<J1137>....<J1187>
digit <zero>;<one>;<two>;<three>;<four>;/
- <five>;<six>;<seven>;<eight>;<nine>
+ <five>;<six>;<seven>;<eight>;<nine>;/
+ <j0316>;<j0317>;<j0318>;<j0319>;<j0320>;/
+ <j0321>;<j0322>;<j0323>;<j0324>;<j0325>
xdigit <zero>;<one>;<two>;<three>;<four>;/
<five>;<six>;<seven>;<eight>;<nine>;/
diff --git a/wcsmbs/mbsrtowcs.c b/wcsmbs/mbsrtowcs.c
index f69247ff85..7c55fec213 100644
--- a/wcsmbs/mbsrtowcs.c
+++ b/wcsmbs/mbsrtowcs.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
+/* Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@gnu.org>, 1996.
@@ -42,9 +42,10 @@ __mbsrtowcs (dst, src, len, ps)
mbstate_t *ps;
{
struct __gconv_step_data data;
- size_t result = 0;
+ size_t result;
int status;
struct __gconv_step *towc;
+ size_t non_reversible;
/* Tell where we want the result. */
data.__invocation_counter = 0;
@@ -65,13 +66,16 @@ __mbsrtowcs (dst, src, len, ps)
const unsigned char *inbuf = (const unsigned char *) *src;
const unsigned char *srcend = inbuf + strlen (inbuf) + 1;
+ result = 0;
data.__outbufend = (char *) buf + sizeof (buf);
do
{
data.__outbuf = (char *) buf;
status = (*towc->__fct) (__wcsmbs_gconv_fcts.towc, &data, &inbuf,
- srcend, &result, 0);
+ srcend, &non_reversible, 0);
+
+ result += (wchar_t *) data.__outbuf - buf;
}
while (status == __GCONV_FULL_OUTPUT);
@@ -99,7 +103,9 @@ __mbsrtowcs (dst, src, len, ps)
status = (*towc->__fct) (__wcsmbs_gconv_fcts.towc, &data,
(const unsigned char **) src, srcend,
- &result, 0);
+ &non_reversible, 0);
+
+ result = (wchar_t *) data.__outbuf - dst;
/* We have to determine whether the last character converted
is the NUL character. */