fix iconv dest utf-16: unavailable chars must be replaced; EILSEQ is wrong
authorRich Felker <dalias@aerifal.cx>
Tue, 19 Jun 2012 00:43:21 +0000 (20:43 -0400)
committerRich Felker <dalias@aerifal.cx>
Tue, 19 Jun 2012 00:43:21 +0000 (20:43 -0400)
src/locale/iconv.c

index c48e45a..78c215e 100644 (file)
@@ -327,14 +327,14 @@ size_t iconv(iconv_t cd0, char **in, size_t *inb, char **out, size_t *outb)
                case UCS2LE:
                case UTF_16BE:
                case UTF_16LE:
-                       if (c < 0x10000) {
+                       if (c < 0x10000 || type-UCS2BE < 2U) {
+                               if (c >= 0x10000) c = 0xFFFD;
                                if (*outb < 2) goto toobig;
                                put_16((void *)*out, c, totype);
                                *out += 2;
                                *outb -= 2;
                                break;
                        }
-                       if (type-UCS2BE < 2U) goto ilseq;
                        if (*outb < 4) goto toobig;
                        c -= 0x10000;
                        put_16((void *)*out, (c>>10)|0xd800, totype);