diff options
Diffstat (limited to 'src/user/lib/file.c')
-rw-r--r-- | src/user/lib/file.c | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/src/user/lib/file.c b/src/user/lib/file.c index c8acbfb..f2b74b1 100644 --- a/src/user/lib/file.c +++ b/src/user/lib/file.c @@ -87,10 +87,11 @@ FILE *fdopen(int fd, const char *mode) { FILE *f; f = malloc(sizeof *f); if (!f) return NULL; + f->fd = fd; f->pos = mode[0] == 'a' ? -1 : 0; f->eof = false; - f->fd = fd; f->error = false; + f->extflags = 0; return f; } @@ -110,6 +111,12 @@ FILE *file_clone(const FILE *f, const char *mode) { return f2; } +int fextflags(FILE *f, int extflags) { + int old = f->extflags; + f->extflags = extflags; + return old; +} + static void fadvance(long amt, FILE *f) { bool pos_neg = f->pos < 0; f->pos += amt; @@ -133,16 +140,16 @@ size_t fread(void *restrict ptr, size_t size, size_t nitems, FILE *restrict f) { if (res < 0) { f->error = true; errno = -res; - return pos/size; + break; } else if (res == 0) { f->eof = true; - return pos/size; - } else { - pos += res; - fadvance(res, f); + break; } + pos += res; + fadvance(res, f); + if (f->extflags & FEXT_NOFILL) break; } - return nitems; + return pos == total ? nitems : (pos/size); } size_t fwrite(const void *restrict ptr, size_t size, size_t nitems, FILE *restrict f) { |