aboutsummaryrefslogtreecommitdiff
path: root/libio/iofwide.c
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2019-11-03 11:39:56 +0100
committerFlorian Weimer <fweimer@redhat.com>2019-11-13 18:18:51 +0100
commit70c6e15654928c603c6d24bd01cf62e7a8e2ce9b (patch)
tree672e377b91c9fc15f00a15d82cd3f0a2f55fba90 /libio/iofwide.c
parent15740788d79447d863b88a5434f09d488d4088d3 (diff)
downloadglibc-70c6e15654928c603c6d24bd01cf62e7a8e2ce9b.tar
glibc-70c6e15654928c603c6d24bd01cf62e7a8e2ce9b.tar.gz
glibc-70c6e15654928c603c6d24bd01cf62e7a8e2ce9b.tar.bz2
glibc-70c6e15654928c603c6d24bd01cf62e7a8e2ce9b.zip
Redefine _IO_iconv_t to store a single gconv step pointer [BZ #25097]
libio can only deal with gconv conversions which consist of a single step. Not using __gconv_info simplifies the data structures somewhat. This eliminates a new GCC 10 warning about subscribing an inner zero-length array. Tested on x86_64-linux-gnu with mainline GCC. Built with build-many-glibcs.py, also with mainline GCC. Due to GCC PR 92039, there are failures left on 32-bit architectures with float128 support. Change-Id: I8b4c489b619a53154712ff32e1b6f13bb92d4203
Diffstat (limited to 'libio/iofwide.c')
-rw-r--r--libio/iofwide.c71
1 files changed, 34 insertions, 37 deletions
diff --git a/libio/iofwide.c b/libio/iofwide.c
index 10e2d66f6b..3acebba07d 100644
--- a/libio/iofwide.c
+++ b/libio/iofwide.c
@@ -80,22 +80,19 @@ _IO_fwide (FILE *fp, int mode)
assert (fcts.towc_nsteps == 1);
assert (fcts.tomb_nsteps == 1);
- cc->__cd_in.__cd.__nsteps = fcts.towc_nsteps;
- cc->__cd_in.__cd.__steps = fcts.towc;
-
- cc->__cd_in.__cd.__data[0].__invocation_counter = 0;
- cc->__cd_in.__cd.__data[0].__internal_use = 1;
- cc->__cd_in.__cd.__data[0].__flags = __GCONV_IS_LAST;
- cc->__cd_in.__cd.__data[0].__statep = &fp->_wide_data->_IO_state;
-
- cc->__cd_out.__cd.__nsteps = fcts.tomb_nsteps;
- cc->__cd_out.__cd.__steps = fcts.tomb;
-
- cc->__cd_out.__cd.__data[0].__invocation_counter = 0;
- cc->__cd_out.__cd.__data[0].__internal_use = 1;
- cc->__cd_out.__cd.__data[0].__flags
- = __GCONV_IS_LAST | __GCONV_TRANSLIT;
- cc->__cd_out.__cd.__data[0].__statep = &fp->_wide_data->_IO_state;
+ cc->__cd_in.step = fcts.towc;
+
+ cc->__cd_in.step_data.__invocation_counter = 0;
+ cc->__cd_in.step_data.__internal_use = 1;
+ cc->__cd_in.step_data.__flags = __GCONV_IS_LAST;
+ cc->__cd_in.step_data.__statep = &fp->_wide_data->_IO_state;
+
+ cc->__cd_out.step = fcts.tomb;
+
+ cc->__cd_out.step_data.__invocation_counter = 0;
+ cc->__cd_out.step_data.__internal_use = 1;
+ cc->__cd_out.step_data.__flags = __GCONV_IS_LAST | __GCONV_TRANSLIT;
+ cc->__cd_out.step_data.__statep = &fp->_wide_data->_IO_state;
}
/* From now on use the wide character callback functions. */
@@ -117,14 +114,14 @@ __libio_codecvt_out (struct _IO_codecvt *codecvt, __mbstate_t *statep,
{
enum __codecvt_result result;
- struct __gconv_step *gs = codecvt->__cd_out.__cd.__steps;
+ struct __gconv_step *gs = codecvt->__cd_out.step;
int status;
size_t dummy;
const unsigned char *from_start_copy = (unsigned char *) from_start;
- codecvt->__cd_out.__cd.__data[0].__outbuf = (unsigned char *) to_start;
- codecvt->__cd_out.__cd.__data[0].__outbufend = (unsigned char *) to_end;
- codecvt->__cd_out.__cd.__data[0].__statep = statep;
+ codecvt->__cd_out.step_data.__outbuf = (unsigned char *) to_start;
+ codecvt->__cd_out.step_data.__outbufend = (unsigned char *) to_end;
+ codecvt->__cd_out.step_data.__statep = statep;
__gconv_fct fct = gs->__fct;
#ifdef PTR_DEMANGLE
@@ -133,12 +130,12 @@ __libio_codecvt_out (struct _IO_codecvt *codecvt, __mbstate_t *statep,
#endif
status = DL_CALL_FCT (fct,
- (gs, codecvt->__cd_out.__cd.__data, &from_start_copy,
+ (gs, &codecvt->__cd_out.step_data, &from_start_copy,
(const unsigned char *) from_end, NULL,
&dummy, 0, 0));
*from_stop = (wchar_t *) from_start_copy;
- *to_stop = (char *) codecvt->__cd_out.__cd.__data[0].__outbuf;
+ *to_stop = (char *) codecvt->__cd_out.step_data.__outbuf;
switch (status)
{
@@ -169,14 +166,14 @@ __libio_codecvt_in (struct _IO_codecvt *codecvt, __mbstate_t *statep,
{
enum __codecvt_result result;
- struct __gconv_step *gs = codecvt->__cd_in.__cd.__steps;
+ struct __gconv_step *gs = codecvt->__cd_in.step;
int status;
size_t dummy;
const unsigned char *from_start_copy = (unsigned char *) from_start;
- codecvt->__cd_in.__cd.__data[0].__outbuf = (unsigned char *) to_start;
- codecvt->__cd_in.__cd.__data[0].__outbufend = (unsigned char *) to_end;
- codecvt->__cd_in.__cd.__data[0].__statep = statep;
+ codecvt->__cd_in.step_data.__outbuf = (unsigned char *) to_start;
+ codecvt->__cd_in.step_data.__outbufend = (unsigned char *) to_end;
+ codecvt->__cd_in.step_data.__statep = statep;
__gconv_fct fct = gs->__fct;
#ifdef PTR_DEMANGLE
@@ -185,12 +182,12 @@ __libio_codecvt_in (struct _IO_codecvt *codecvt, __mbstate_t *statep,
#endif
status = DL_CALL_FCT (fct,
- (gs, codecvt->__cd_in.__cd.__data, &from_start_copy,
+ (gs, &codecvt->__cd_in.step_data, &from_start_copy,
(const unsigned char *) from_end, NULL,
&dummy, 0, 0));
*from_stop = (const char *) from_start_copy;
- *to_stop = (wchar_t *) codecvt->__cd_in.__cd.__data[0].__outbuf;
+ *to_stop = (wchar_t *) codecvt->__cd_in.step_data.__outbuf;
switch (status)
{
@@ -217,16 +214,16 @@ int
__libio_codecvt_encoding (struct _IO_codecvt *codecvt)
{
/* See whether the encoding is stateful. */
- if (codecvt->__cd_in.__cd.__steps[0].__stateful)
+ if (codecvt->__cd_in.step->__stateful)
return -1;
/* Fortunately not. Now determine the input bytes for the conversion
necessary for each wide character. */
- if (codecvt->__cd_in.__cd.__steps[0].__min_needed_from
- != codecvt->__cd_in.__cd.__steps[0].__max_needed_from)
+ if (codecvt->__cd_in.step->__min_needed_from
+ != codecvt->__cd_in.step->__max_needed_from)
/* Not a constant value. */
return 0;
- return codecvt->__cd_in.__cd.__steps[0].__min_needed_from;
+ return codecvt->__cd_in.step->__min_needed_from;
}
@@ -238,12 +235,12 @@ __libio_codecvt_length (struct _IO_codecvt *codecvt, __mbstate_t *statep,
int result;
const unsigned char *cp = (const unsigned char *) from_start;
wchar_t to_buf[max];
- struct __gconv_step *gs = codecvt->__cd_in.__cd.__steps;
+ struct __gconv_step *gs = codecvt->__cd_in.step;
size_t dummy;
- codecvt->__cd_in.__cd.__data[0].__outbuf = (unsigned char *) to_buf;
- codecvt->__cd_in.__cd.__data[0].__outbufend = (unsigned char *) &to_buf[max];
- codecvt->__cd_in.__cd.__data[0].__statep = statep;
+ codecvt->__cd_in.step_data.__outbuf = (unsigned char *) to_buf;
+ codecvt->__cd_in.step_data.__outbufend = (unsigned char *) &to_buf[max];
+ codecvt->__cd_in.step_data.__statep = statep;
__gconv_fct fct = gs->__fct;
#ifdef PTR_DEMANGLE
@@ -252,7 +249,7 @@ __libio_codecvt_length (struct _IO_codecvt *codecvt, __mbstate_t *statep,
#endif
DL_CALL_FCT (fct,
- (gs, codecvt->__cd_in.__cd.__data, &cp,
+ (gs, &codecvt->__cd_in.step_data, &cp,
(const unsigned char *) from_end, NULL,
&dummy, 0, 0));