fmemopen: fix eof handling, hopefully right this time
[musl] / src / stdio / fmemopen.c
index f518528..e2adfb2 100644 (file)
@@ -16,7 +16,7 @@ fail:
                return -1;
        }
        base = (size_t [3]){0, c->pos, c->len}[whence];
-       if (off < -base || off > SSIZE_MAX-base) goto fail;
+       if (off < -base || off > (ssize_t)c->size-base) goto fail;
        return c->pos = base+off;
 }
 
@@ -24,7 +24,10 @@ static size_t mread(FILE *f, unsigned char *buf, size_t len)
 {
        struct cookie *c = f->cookie;
        size_t rem = c->size - c->pos;
-       if (len > rem) len = rem;
+       if (len > rem) {
+               len = rem;
+               f->flags |= F_EOF;
+       }
        memcpy(buf, c->buf+c->pos, len);
        c->pos += len;
        rem -= len;
@@ -32,7 +35,7 @@ static size_t mread(FILE *f, unsigned char *buf, size_t len)
        f->rpos = f->buf;
        f->rend = f->buf + rem;
        memcpy(f->rpos, c->buf+c->pos, rem);
-       if (!len) f->flags |= F_EOF;
+       c->pos += rem;
        return len;
 }