X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fstdio%2Ffgets.c;h=3135a69a2b9ebfe7b8475af708295c9e7e626056;hb=aed707f679cce80afd929f0efaf080f1e8481330;hp=7939303e60b17df093748d8d756765074f360561;hpb=0b44a0315b47dd8eced9f3b7f31580cf14bbfc01;p=musl diff --git a/src/stdio/fgets.c b/src/stdio/fgets.c index 7939303e..3135a69a 100644 --- a/src/stdio/fgets.c +++ b/src/stdio/fgets.c @@ -7,12 +7,17 @@ char *fgets(char *s, int n, FILE *f) char *p = s; unsigned char *z; size_t k; + int c; - if (!n--) return 0; + if (n--<=1) { + if (n) return 0; + *s = 0; + return s; + } FLOCK(f); - while (n && !feof(f)) { + while (n) { z = memchr(f->rpos, '\n', f->rend - f->rpos); k = z ? z - f->rpos + 1 : f->rend - f->rpos; k = MIN(k, n); @@ -20,15 +25,19 @@ char *fgets(char *s, int n, FILE *f) f->rpos += k; p += k; n -= k; - if (z) break; - __underflow(f); + if (z || !n) break; + if ((c = getc_unlocked(f)) < 0) { + if (p==s || !feof(f)) s = 0; + break; + } + n--; + if ((*p++ = c) == '\n') break; } *p = 0; - if (ferror(f)) p = s; FUNLOCK(f); - return (p == s) ? 0 : s; + return s; } weak_alias(fgets, fgets_unlocked);