diff options
author | Rich Felker <dalias@aerifal.cx> | 2016-02-10 19:10:34 -0500 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2016-02-10 19:10:34 -0500 |
commit | 416d1c7a711807384cc21a18163475cf757bbcb5 (patch) | |
tree | 8a31270eb7640693929a0d4447e42e34f83cb687 | |
parent | 5a6e8d098abfef67028e6c3edbac39e0bbaf8bd8 (diff) | |
download | musl-416d1c7a711807384cc21a18163475cf757bbcb5.tar.gz musl-416d1c7a711807384cc21a18163475cf757bbcb5.tar.bz2 musl-416d1c7a711807384cc21a18163475cf757bbcb5.tar.xz musl-416d1c7a711807384cc21a18163475cf757bbcb5.zip |
fix line-buffered flush omission for odd usage of putc-family functions
as specified, the int argument providing the character to write is
converted to type unsigned char. for the actual write to buffer,
conversion happened implicitly via the assignment operator; however,
the logic to check whether the argument was a newline used the
original int value. thus usage such as putchar('\n'+0x100) failed to
produce a flush.
-rw-r--r-- | src/internal/stdio_impl.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/internal/stdio_impl.h b/src/internal/stdio_impl.h index 0dd7fb5e..7cdf729d 100644 --- a/src/internal/stdio_impl.h +++ b/src/internal/stdio_impl.h @@ -86,7 +86,8 @@ void __ofl_unlock(void); #define getc_unlocked(f) \ ( ((f)->rpos < (f)->rend) ? *(f)->rpos++ : __uflow((f)) ) -#define putc_unlocked(c, f) ( ((c)!=(f)->lbf && (f)->wpos<(f)->wend) \ +#define putc_unlocked(c, f) \ + ( ((unsigned char)(c)!=(f)->lbf && (f)->wpos<(f)->wend) \ ? *(f)->wpos++ = (c) : __overflow((f),(c)) ) /* Caller-allocated FILE * operations */ |