X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fdata-in.c;h=7e7d087d51dcfa1ab9811715ff7354f106081bae;hb=8830c95bb9e8d72621787866141a27fc22e8c786;hp=e7a83f25b44a5f7a55d2c46e20aed4dc7785e40e;hpb=9254d30d06a0565c89daccedd93a94c4c6086004;p=pspp-builds.git diff --git a/src/data/data-in.c b/src/data/data-in.c index e7a83f25..7e7d087d 100644 --- a/src/data/data-in.c +++ b/src/data/data-in.c @@ -37,6 +37,7 @@ #include #include +#include #include #include #include @@ -124,9 +125,12 @@ data_in (struct substring input, const char *encoding, } else { + char *s; ss_alloc_uninit (&i.input, ss_length (input)); - legacy_recode (encoding, ss_data (input), LEGACY_NATIVE, - ss_data (i.input), ss_length (input)); + + s = recode_string (LEGACY_NATIVE, encoding, ss_data (input), ss_length (input)); + memcpy (ss_data (i.input), s, ss_length (input)); + free (s); i.encoding = LEGACY_NATIVE; copy = ss_data (i.input); } @@ -608,12 +612,14 @@ parse_A (struct data_in *i) { /* This is equivalent to buf_copy_rpad, except that we posibly do a character set recoding in the middle. */ - char *dst = value_str_rw (i->output, i->width); + uint8_t *dst = value_str_rw (i->output, i->width); size_t dst_size = i->width; const char *src = ss_data (i->input); size_t src_size = ss_length (i->input); - legacy_recode (i->encoding, src, LEGACY_NATIVE, dst, MIN (src_size, dst_size)); + char *s = recode_string (LEGACY_NATIVE, i->encoding, src, MIN (src_size, dst_size)); + memcpy (dst, s, dst_size); + free (s); if (dst_size > src_size) memset (&dst[src_size], ' ', dst_size - src_size); @@ -624,7 +630,7 @@ parse_A (struct data_in *i) static bool parse_AHEX (struct data_in *i) { - char *s = value_str_rw (i->output, i->width); + uint8_t *s = value_str_rw (i->output, i->width); size_t j; for (j = 0; ; j++)