diff options
Diffstat (limited to 'src/stdio')
-rw-r--r-- | src/stdio/__stdio_read.c | 1 | ||||
-rw-r--r-- | src/stdio/__toread.c | 8 | ||||
-rw-r--r-- | src/stdio/__uflow.c | 6 | ||||
-rw-r--r-- | src/stdio/ungetc.c | 3 | ||||
-rw-r--r-- | src/stdio/ungetwc.c | 3 |
5 files changed, 11 insertions, 10 deletions
diff --git a/src/stdio/__stdio_read.c b/src/stdio/__stdio_read.c index 6cd7b073..59473444 100644 --- a/src/stdio/__stdio_read.c +++ b/src/stdio/__stdio_read.c @@ -21,7 +21,6 @@ size_t __stdio_read(FILE *f, unsigned char *buf, size_t len) pthread_cleanup_pop(0); if (cnt <= 0) { f->flags |= F_EOF ^ ((F_ERR^F_EOF) & cnt); - f->rpos = f->rend = 0; return cnt; } if (cnt <= iov[0].iov_len) return cnt; diff --git a/src/stdio/__toread.c b/src/stdio/__toread.c index 52624f3d..b08f5bb4 100644 --- a/src/stdio/__toread.c +++ b/src/stdio/__toread.c @@ -5,12 +5,12 @@ int __toread(FILE *f) f->mode |= f->mode-1; if (f->wpos > f->buf) f->write(f, 0, 0); f->wpos = f->wbase = f->wend = 0; - if (f->flags & (F_EOF|F_NORD)) { - if (f->flags & F_NORD) f->flags |= F_ERR; + if (f->flags & F_NORD) { + f->flags |= F_ERR; return EOF; } - f->rpos = f->rend = f->buf; - return 0; + f->rpos = f->rend = f->buf + f->buf_size; + return (f->flags & F_EOF) ? EOF : 0; } void __stdio_exit_needed(void); diff --git a/src/stdio/__uflow.c b/src/stdio/__uflow.c index e28922c2..2a88bca6 100644 --- a/src/stdio/__uflow.c +++ b/src/stdio/__uflow.c @@ -1,11 +1,11 @@ #include "stdio_impl.h" -/* This function will never be called if there is already data - * buffered for reading. Thus we can get by with very few branches. */ +/* This function assumes it will never be called if there is already + * data buffered for reading. */ int __uflow(FILE *f) { unsigned char c; - if ((f->rend || !__toread(f)) && f->read(f, &c, 1)==1) return c; + if (!__toread(f) && f->read(f, &c, 1)==1) return c; return EOF; } diff --git a/src/stdio/ungetc.c b/src/stdio/ungetc.c index 7f56f8d5..180673a4 100644 --- a/src/stdio/ungetc.c +++ b/src/stdio/ungetc.c @@ -6,7 +6,8 @@ int ungetc(int c, FILE *f) FLOCK(f); - if ((!f->rend && __toread(f)) || f->rpos <= f->buf - UNGET) { + if (!f->rpos) __toread(f); + if (!f->rpos || f->rpos <= f->buf - UNGET) { FUNLOCK(f); return EOF; } diff --git a/src/stdio/ungetwc.c b/src/stdio/ungetwc.c index 8cc85a6b..913f7168 100644 --- a/src/stdio/ungetwc.c +++ b/src/stdio/ungetwc.c @@ -19,7 +19,8 @@ wint_t ungetwc(wint_t c, FILE *f) f->mode |= f->mode+1; - if ((!f->rend && __toread(f)) || f->rpos < f->buf - UNGET + l) { + if (!f->rpos) __toread(f); + if (!f->rpos || f->rpos < f->buf - UNGET + l) { FUNLOCK(f); return EOF; } |