* posix/regexec.c (check_node_accept_bytes): Correct cast to avoid

warning.
	* posix/regex_internal.c (re_string_reconstruct): Add cast to
	avoid warning.
	(build_wcs_upper_buffer): Change type of bug to plain char.
	* locale/weightwc.h (findidx): Add casts to avoid warnings.
	* time/mktime.c (ranged_convert): Initialize tm to make the
	compiler happy.
	* wcsmbs/mbsrtowcs_l.c (__mbsrtowcs_l): Add casts to avoid warnings.
	* wcsmbs/wcsnrtombs.c (__wcsnrtombs): Add casts to avoid warnings.
	* wcsmbs/mbsnrtowcs.c: Add casts to avoid warnings.
	* wcsmbs/wcsrtombs.c (__wcsrtombs): Add casts to avoid warnings.
	* wcsmbs/wcrtomb.c (__wcrtomb): Add casts to avoid warnings.
	* wcsmbs/mbrtowc.c (__mbrtowc): Use unsigned char for outbuf.
	* posix/regex_internal.c [_LIBC] (build_wcs_buffer): Avoid using
	dynamically sized array.
	(build_wcs_upper_buffer): Likewise.
This commit is contained in:
Ulrich Drepper 2005-03-06 07:27:56 +00:00
parent 3cc4a09733
commit 1c99f950d1
11 changed files with 59 additions and 41 deletions

View File

@ -1,5 +1,19 @@
2005-03-05 Ulrich Drepper <drepper@redhat.com> 2005-03-05 Ulrich Drepper <drepper@redhat.com>
* posix/regexec.c (check_node_accept_bytes): Correct cast to avoid
warning.
* posix/regex_internal.c (re_string_reconstruct): Add cast to
avoid warning.
(build_wcs_upper_buffer): Change type of bug to plain char.
* locale/weightwc.h (findidx): Add casts to avoid warnings.
* time/mktime.c (ranged_convert): Initialize tm to make the
compiler happy.
* wcsmbs/mbsrtowcs_l.c (__mbsrtowcs_l): Add casts to avoid warnings.
* wcsmbs/wcsnrtombs.c (__wcsnrtombs): Add casts to avoid warnings.
* wcsmbs/mbsnrtowcs.c: Add casts to avoid warnings.
* wcsmbs/wcsrtombs.c (__wcsrtombs): Add casts to avoid warnings.
* wcsmbs/wcrtomb.c (__wcrtomb): Add casts to avoid warnings.
* wcsmbs/mbrtowc.c (__mbrtowc): Use unsigned char for outbuf.
* wcsmbs/wctob.c (wctob): Make buf array of unsigned char. * wcsmbs/wctob.c (wctob): Make buf array of unsigned char.
* sysdeps/generic/strchrnul.c: Add cast to avoid warning. * sysdeps/generic/strchrnul.c: Add cast to avoid warning.
* libio/iofwide.c: Add casts to avoid warnings. * libio/iofwide.c: Add casts to avoid warnings.
@ -10,6 +24,10 @@
* iconv/gconv_simple.c (internal_utf8_loop): Make start unsigned * iconv/gconv_simple.c (internal_utf8_loop): Make start unsigned
to avoid warning. to avoid warning.
* posix/regex_internal.c [_LIBC] (build_wcs_buffer): Avoid using
dynamically sized array.
(build_wcs_upper_buffer): Likewise.
2005-03-05 Jakub Jelinek <jakub@redhat.com> 2005-03-05 Jakub Jelinek <jakub@redhat.com>
* include/bits/unistd.h: New file. * include/bits/unistd.h: New file.

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996-2000, 2001,2003,2004 Free Software Foundation, Inc. /* Copyright (C) 1996-2001,2003,2004,2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Written by Ulrich Drepper, <drepper@cygnus.com>. Written by Ulrich Drepper, <drepper@cygnus.com>.
@ -22,12 +22,8 @@ auto inline int32_t
__attribute ((always_inline)) __attribute ((always_inline))
findidx (const wint_t **cpp) findidx (const wint_t **cpp)
{ {
int32_t i; wint_t ch = *(*cpp)++;
const wint_t *cp; int32_t i = __collidx_table_lookup ((const char *) table, ch);
wint_t ch;
ch = *(*cpp)++;
i = __collidx_table_lookup ((const char *) table, ch);
if (i >= 0) if (i >= 0)
/* This is an index into the weight table. Cool. */ /* This is an index into the weight table. Cool. */
@ -35,11 +31,11 @@ findidx (const wint_t **cpp)
/* Oh well, more than one sequence starting with this byte. /* Oh well, more than one sequence starting with this byte.
Search for the correct one. */ Search for the correct one. */
cp = &extra[-i]; const int32_t *cp = &extra[-i];
while (1) while (1)
{ {
size_t nhere; size_t nhere;
const wint_t *usrc = *cpp; const int32_t *usrc = (const int32_t *) *cpp;
/* The first thing is the index. */ /* The first thing is the index. */
i = *cp++; i = *cp++;

View File

@ -1,5 +1,5 @@
/* Extended regular expression matching and search library. /* Extended regular expression matching and search library.
Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc. Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Isamu Hasegawa <isamu@yamato.ibm.com>. Contributed by Isamu Hasegawa <isamu@yamato.ibm.com>.
@ -214,7 +214,8 @@ build_wcs_buffer (pstr)
re_string_t *pstr; re_string_t *pstr;
{ {
#ifdef _LIBC #ifdef _LIBC
unsigned char buf[pstr->mb_cur_max]; unsigned char buf[MB_CUR_MAX];
assert (MB_CUR_MAX >= pstr->mb_cur_max);
#else #else
unsigned char buf[64]; unsigned char buf[64];
#endif #endif
@ -282,9 +283,10 @@ build_wcs_upper_buffer (pstr)
mbstate_t prev_st; mbstate_t prev_st;
int src_idx, byte_idx, end_idx, mbclen, remain_len; int src_idx, byte_idx, end_idx, mbclen, remain_len;
#ifdef _LIBC #ifdef _LIBC
unsigned char buf[pstr->mb_cur_max]; char buf[MB_CUR_MAX];
assert (MB_CUR_MAX >= pstr->mb_cur_max);
#else #else
unsigned char buf[64]; char buf[64];
#endif #endif
byte_idx = pstr->valid_len; byte_idx = pstr->valid_len;
@ -666,8 +668,9 @@ re_string_reconstruct (pstr, idx, eflags)
/* XXX Don't use mbrtowc, we know which conversion /* XXX Don't use mbrtowc, we know which conversion
to use (UTF-8 -> UCS4). */ to use (UTF-8 -> UCS4). */
memset (&cur_state, 0, sizeof (cur_state)); memset (&cur_state, 0, sizeof (cur_state));
mlen = mbrtowc (&wc2, p, mlen, &cur_state) mlen = (mbrtowc (&wc2, (const char *) p, mlen,
- (raw + offset - p); &cur_state)
- (raw + offset - p));
if (mlen >= 0) if (mlen >= 0)
{ {
memset (&pstr->cur_state, '\0', memset (&pstr->cur_state, '\0',

View File

@ -1,5 +1,5 @@
/* Extended regular expression matching and search library. /* Extended regular expression matching and search library.
Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc. Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Isamu Hasegawa <isamu@yamato.ibm.com>. Contributed by Isamu Hasegawa <isamu@yamato.ibm.com>.
@ -3781,8 +3781,8 @@ check_node_accept_bytes (dfa, node_idx, input, str_idx)
{ {
const re_charset_t *cset = node->opr.mbcset; const re_charset_t *cset = node->opr.mbcset;
# ifdef _LIBC # ifdef _LIBC
const unsigned char *pin = ((char *) re_string_get_buffer (input) const unsigned char *pin
+ str_idx); = ((const unsigned char *) re_string_get_buffer (input) + str_idx);
int j; int j;
uint32_t nrules; uint32_t nrules;
# endif /* _LIBC */ # endif /* _LIBC */

View File

@ -1,5 +1,5 @@
/* Convert a `struct tm' to a time_t value. /* Convert a `struct tm' to a time_t value.
Copyright (C) 1993-1999, 2002, 2003, 2004 Free Software Foundation, Inc. Copyright (C) 1993-1999, 2002-2004, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Paul Eggert (eggert@twinsun.com). Contributed by Paul Eggert (eggert@twinsun.com).
@ -209,7 +209,8 @@ ranged_convert (struct tm *(*convert) (const time_t *, struct tm *),
{ {
time_t bad = *t; time_t bad = *t;
time_t ok = 0; time_t ok = 0;
struct tm tm; /* Initialize to make the compiler happy. */
struct tm tm = { 0, };
/* BAD is a known unconvertible time_t, and OK is a known good one. /* BAD is a known unconvertible time_t, and OK is a known good one.
Use binary search to narrow the range between BAD and OK until Use binary search to narrow the range between BAD and OK until

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996, 1997, 1998, 1999, 2000, 2002, 2004 /* Copyright (C) 1996, 1997, 1998, 1999, 2000, 2002, 2004, 2005
Free Software Foundation, Inc. Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@gnu.org>, 1996. Contributed by Ulrich Drepper <drepper@gnu.org>, 1996.
@ -42,7 +42,7 @@ __mbrtowc (wchar_t *pwc, const char *s, size_t n, mbstate_t *ps)
size_t result; size_t result;
size_t dummy; size_t dummy;
const unsigned char *inbuf, *endbuf; const unsigned char *inbuf, *endbuf;
char *outbuf = (char *) (pwc ?: buf); unsigned char *outbuf = (unsigned char *) (pwc ?: buf);
const struct gconv_fcts *fcts; const struct gconv_fcts *fcts;
/* Set information for this step. */ /* Set information for this step. */
@ -56,7 +56,7 @@ __mbrtowc (wchar_t *pwc, const char *s, size_t n, mbstate_t *ps)
initial state. */ initial state. */
if (s == NULL) if (s == NULL)
{ {
outbuf = (char *) buf; outbuf = (unsigned char *) buf;
s = ""; s = "";
n = 1; n = 1;
} }

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996,1997,1998,1999,2000,2002 Free Software Foundation, Inc. /* Copyright (C) 1996-2000, 2002, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@gnu.org>, 1996. Contributed by Ulrich Drepper <drepper@gnu.org>, 1996.
@ -62,7 +62,7 @@ __mbsnrtowcs (dst, src, nmc, len, ps)
if (nmc == 0) if (nmc == 0)
return 0; return 0;
srcend = *src + __strnlen (*src, nmc - 1) + 1; srcend = (const unsigned char *) *src + __strnlen (*src, nmc - 1) + 1;
/* Get the conversion functions. */ /* Get the conversion functions. */
fcts = get_gconv_fcts (_NL_CURRENT_DATA (LC_CTYPE)); fcts = get_gconv_fcts (_NL_CURRENT_DATA (LC_CTYPE));
@ -74,7 +74,7 @@ __mbsnrtowcs (dst, src, nmc, len, ps)
if (dst == NULL) if (dst == NULL)
{ {
wchar_t buf[64]; /* Just an arbitrary size. */ wchar_t buf[64]; /* Just an arbitrary size. */
const unsigned char *inbuf = *src; const unsigned char *inbuf = (const unsigned char *) *src;
result = 0; result = 0;
data.__outbufend = (unsigned char *) buf + sizeof (buf); data.__outbufend = (unsigned char *) buf + sizeof (buf);

View File

@ -1,4 +1,4 @@
/* Copyright (C) 2002, 2004 Free Software Foundation, Inc. /* Copyright (C) 2002, 2004, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@gnu.org>, 2002. Contributed by Ulrich Drepper <drepper@gnu.org>, 2002.
@ -70,16 +70,16 @@ __mbsrtowcs_l (dst, src, len, ps, l)
mbstate_t temp_state; mbstate_t temp_state;
wchar_t buf[64]; /* Just an arbitrary size. */ wchar_t buf[64]; /* Just an arbitrary size. */
const unsigned char *inbuf = (const unsigned char *) *src; const unsigned char *inbuf = (const unsigned char *) *src;
const unsigned char *srcend = inbuf + strlen (inbuf) + 1; const unsigned char *srcend = inbuf + strlen (*src) + 1;
temp_state = *data.__statep; temp_state = *data.__statep;
data.__statep = &temp_state; data.__statep = &temp_state;
result = 0; result = 0;
data.__outbufend = (char *) buf + sizeof (buf); data.__outbufend = (unsigned char *) buf + sizeof (buf);
do do
{ {
data.__outbuf = (char *) buf; data.__outbuf = (unsigned char *) buf;
status = DL_CALL_FCT (towc->__fct, status = DL_CALL_FCT (towc->__fct,
(towc, &data, &inbuf, srcend, NULL, (towc, &data, &inbuf, srcend, NULL,
@ -114,7 +114,7 @@ __mbsrtowcs_l (dst, src, len, ps, l)
{ {
/* Pessimistic guess as to how much input we can use. In the /* Pessimistic guess as to how much input we can use. In the
worst case we need one input byte for one output wchar_t. */ worst case we need one input byte for one output wchar_t. */
srcend = srcp + __strnlen (srcp, len) + 1; srcend = srcp + __strnlen ((const char *) srcp, len) + 1;
status = DL_CALL_FCT (towc->__fct, status = DL_CALL_FCT (towc->__fct,
(towc, &data, &srcp, srcend, NULL, (towc, &data, &srcp, srcend, NULL,
@ -131,7 +131,7 @@ __mbsrtowcs_l (dst, src, len, ps, l)
} }
/* Make the end if the input known to the caller. */ /* Make the end if the input known to the caller. */
*src = srcp; *src = (const char *) srcp;
result = (wchar_t *) data.__outbuf - dst; result = (wchar_t *) data.__outbuf - dst;

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996,1997,1998,2000,2002 Free Software Foundation, Inc. /* Copyright (C) 1996,1997,1998,2000,2002,2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
@ -60,8 +60,8 @@ __wcrtomb (char *s, wchar_t wc, mbstate_t *ps)
} }
/* Tell where we want to have the result. */ /* Tell where we want to have the result. */
data.__outbuf = s; data.__outbuf = (unsigned char *) s;
data.__outbufend = s + MB_CUR_MAX; data.__outbufend = (unsigned char *) s + MB_CUR_MAX;
/* Get the conversion functions. */ /* Get the conversion functions. */
fcts = get_gconv_fcts (_NL_CURRENT_DATA (LC_CTYPE)); fcts = get_gconv_fcts (_NL_CURRENT_DATA (LC_CTYPE));

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996-2000, 2002, 2003 Free Software Foundation, Inc. /* Copyright (C) 1996-2000, 2002, 2003, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@gnu.org>, 1996. Contributed by Ulrich Drepper <drepper@gnu.org>, 1996.
@ -104,8 +104,8 @@ __wcsnrtombs (dst, src, nwc, len, ps)
of the string. */ of the string. */
size_t dummy; size_t dummy;
data.__outbuf = dst; data.__outbuf = (unsigned char *) dst;
data.__outbufend = dst + len; data.__outbufend = (unsigned char *) dst + len;
status = DL_CALL_FCT (tomb->__fct, status = DL_CALL_FCT (tomb->__fct,
(tomb, &data, (const unsigned char **) src, (tomb, &data, (const unsigned char **) src,

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1996-2000, 2002, 2003 Free Software Foundation, Inc. /* Copyright (C) 1996-2000, 2002, 2003, 2005 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@gnu.org>, 1996. Contributed by Ulrich Drepper <drepper@gnu.org>, 1996.
@ -105,8 +105,8 @@ __wcsrtombs (dst, src, len, ps)
const wchar_t *srcend = *src + __wcsnlen (*src, len) + 1; const wchar_t *srcend = *src + __wcsnlen (*src, len) + 1;
size_t dummy; size_t dummy;
data.__outbuf = dst; data.__outbuf = (unsigned char *) dst;
data.__outbufend = dst + len; data.__outbufend = (unsigned char *) dst + len;
status = DL_CALL_FCT (tomb->__fct, status = DL_CALL_FCT (tomb->__fct,
(tomb, &data, (const unsigned char **) src, (tomb, &data, (const unsigned char **) src,