2004-01-21 Jeff Johnston <jjohnstn@redhat.com>
* libc/stdlib/mbrtowc.c (_mbrtowc_r): Fix case where s is null pointer to match C99 spec. * libc/stdlib/mbsrtowcs.c (_mbsrtowc_r): Fix to ignore len when dst is NULL. Also fix to not alter src pointer when dst is NULL and call _mbrtowc_r instead of _mbtowc_r. * libc/stdlib/wcsrtombs.c (_wcsrtombs_r): Call _wcrtomb_r instead of _wctomb_r.
This commit is contained in:
parent
a1dcf5d848
commit
7d4be1efd5
@ -1,3 +1,13 @@
|
||||
2004-01-21 Jeff Johnston <jjohnstn@redhat.com>
|
||||
|
||||
* libc/stdlib/mbrtowc.c (_mbrtowc_r): Fix case where s is null
|
||||
pointer to match C99 spec.
|
||||
* libc/stdlib/mbsrtowcs.c (_mbsrtowc_r): Fix to ignore len when
|
||||
dst is NULL. Also fix to not alter src pointer when dst is NULL
|
||||
and call _mbrtowc_r instead of _mbtowc_r.
|
||||
* libc/stdlib/wcsrtombs.c (_wcsrtombs_r): Call _wcrtomb_r instead
|
||||
of _wctomb_r.
|
||||
|
||||
2004-01-19 Thomas Pfaff <tpfaff@gmx.net>
|
||||
|
||||
* libc/stdio/fclose.c (fclose): Release FILE as the last step.
|
||||
|
@ -24,7 +24,7 @@ _DEFUN (_mbrtowc_r, (ptr, pwc, s, n, ps),
|
||||
#endif
|
||||
|
||||
if (s == NULL)
|
||||
retval = _mbtowc_r (ptr, pwc, "", 1, ps);
|
||||
retval = _mbtowc_r (ptr, NULL, "", 1, ps);
|
||||
else
|
||||
retval = _mbtowc_r (ptr, pwc, s, n, ps);
|
||||
|
||||
|
@ -13,7 +13,9 @@ _DEFUN (_mbsrtowcs_r, (r, dst, src, n, ps),
|
||||
mbstate_t *ps)
|
||||
{
|
||||
wchar_t *ptr = dst;
|
||||
size_t max = n;
|
||||
const char *tmp_src;
|
||||
size_t max;
|
||||
size_t count = 0;
|
||||
int bytes;
|
||||
|
||||
#ifdef MB_CAPABLE
|
||||
@ -24,13 +26,24 @@ _DEFUN (_mbsrtowcs_r, (r, dst, src, n, ps),
|
||||
}
|
||||
#endif
|
||||
|
||||
if (dst == NULL)
|
||||
{
|
||||
/* Ignore original n value and do not alter src pointer if the
|
||||
dst pointer is NULL. */
|
||||
n = (size_t)-1;
|
||||
tmp_src = *src;
|
||||
src = &tmp_src;
|
||||
}
|
||||
|
||||
max = n;
|
||||
while (n > 0)
|
||||
{
|
||||
bytes = _mbtowc_r (r, ptr, *src, MB_CUR_MAX, ps);
|
||||
bytes = _mbrtowc_r (r, ptr, *src, MB_CUR_MAX, ps);
|
||||
if (bytes > 0)
|
||||
{
|
||||
*src += bytes;
|
||||
++ptr;
|
||||
++count;
|
||||
ptr = (dst == NULL) ? NULL : ptr + 1;
|
||||
--n;
|
||||
}
|
||||
else if (bytes == -2)
|
||||
@ -40,7 +53,7 @@ _DEFUN (_mbsrtowcs_r, (r, dst, src, n, ps),
|
||||
else if (bytes == 0)
|
||||
{
|
||||
*src = NULL;
|
||||
return (size_t)(ptr - dst);
|
||||
return count;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -37,7 +37,7 @@ _DEFUN (_wcsrtombs_r, (r, dst, src, len, ps),
|
||||
{
|
||||
int count = ps->__count;
|
||||
wint_t wch = ps->__value.__wch;
|
||||
int bytes = _wctomb_r (r, buff, *pwcs, ps);
|
||||
int bytes = _wcrtomb_r (r, buff, *pwcs, ps);
|
||||
if (bytes == -1)
|
||||
{
|
||||
r->_errno = EILSEQ;
|
||||
|
Loading…
Reference in New Issue
Block a user