diff options
author | Rich Felker <dalias@aerifal.cx> | 2015-06-13 05:17:16 +0000 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2015-06-13 05:17:16 +0000 |
commit | 536c6d5a4205e2a3f161f2983ce1e0ac3082187d (patch) | |
tree | a45cf47d93d62585cd417b83bd49100edf419222 /src/stdio/fputws.c | |
parent | f8f565df467c13248104223f99abf7f37cef7584 (diff) | |
download | musl-536c6d5a4205e2a3f161f2983ce1e0ac3082187d.tar.gz musl-536c6d5a4205e2a3f161f2983ce1e0ac3082187d.tar.bz2 musl-536c6d5a4205e2a3f161f2983ce1e0ac3082187d.tar.xz musl-536c6d5a4205e2a3f161f2983ce1e0ac3082187d.zip |
fix idiom for setting stdio stream orientation to wide
the old idiom, f->mode |= f->mode+1, was adapted from the idiom for
setting byte orientation, f->mode |= f->mode-1, but the adaptation was
incorrect. unless the stream was alreasdy set byte-oriented, this code
incremented f->mode each time it was executed, which would eventually
lead to overflow. it could be fixed by changing it to f->mode |= 1,
but upcoming changes will require slightly more work at the time of
wide orientation, so it makes sense to just call fwide. as an
optimization in the single-character functions, fwide is only called
if the stream is not already wide-oriented.
Diffstat (limited to 'src/stdio/fputws.c')
-rw-r--r-- | src/stdio/fputws.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/stdio/fputws.c b/src/stdio/fputws.c index 5723cbcd..317d65f1 100644 --- a/src/stdio/fputws.c +++ b/src/stdio/fputws.c @@ -8,7 +8,7 @@ int fputws(const wchar_t *restrict ws, FILE *restrict f) FLOCK(f); - f->mode |= f->mode+1; + fwide(f, 1); while (ws && (l = wcsrtombs((void *)buf, (void*)&ws, sizeof buf, 0))+1 > 1) if (__fwritex(buf, l, f) < l) { |