diff options
Diffstat (limited to 'lib/io/src')
-rw-r--r-- | lib/io/src/mem.c | 3 | ||||
-rw-r--r-- | lib/io/src/unix/istream.c | 5 | ||||
-rw-r--r-- | lib/io/src/win32/istream.c | 7 | ||||
-rw-r--r-- | lib/io/src/xfrm/istream.c | 9 |
4 files changed, 8 insertions, 16 deletions
diff --git a/lib/io/src/mem.c b/lib/io/src/mem.c index b1abbdb..39e0d6b 100644 --- a/lib/io/src/mem.c +++ b/lib/io/src/mem.c @@ -51,9 +51,6 @@ static int mem_in_precache(istream_t *strm) mem->size -= diff; } - if (mem->size == 0) - strm->eof = true; - return 0; } diff --git a/lib/io/src/unix/istream.c b/lib/io/src/unix/istream.c index db870d9..8a2dc26 100644 --- a/lib/io/src/unix/istream.c +++ b/lib/io/src/unix/istream.c @@ -11,6 +11,7 @@ typedef struct { char *path; int fd; + bool eof; sqfs_u8 buffer[BUFSZ]; } file_istream_t; @@ -29,12 +30,12 @@ static int file_precache(istream_t *strm) strm->buffer = file->buffer; - while (!strm->eof && strm->buffer_used < BUFSZ) { + while (!file->eof && strm->buffer_used < BUFSZ) { ssize_t ret = read(file->fd, file->buffer + strm->buffer_used, BUFSZ - strm->buffer_used); if (ret == 0) - strm->eof = true; + file->eof = true; if (ret < 0) { if (errno == EINTR) diff --git a/lib/io/src/win32/istream.c b/lib/io/src/win32/istream.c index 94c8584..c4d7458 100644 --- a/lib/io/src/win32/istream.c +++ b/lib/io/src/win32/istream.c @@ -14,6 +14,7 @@ typedef struct { char *path; HANDLE hnd; + bool eof; sqfs_u8 buffer[BUFSZ]; } file_istream_t; @@ -23,7 +24,7 @@ static int file_precache(istream_t *strm) DWORD diff, actual; HANDLE hnd; - if (strm->eof) + if (file->eof) return 0; assert(strm->buffer >= file->buffer); @@ -47,7 +48,7 @@ static int file_precache(istream_t *strm) if (error == ERROR_HANDLE_EOF || error == ERROR_BROKEN_PIPE) { - strm->eof = true; + file->eof = true; break; } @@ -58,7 +59,7 @@ static int file_precache(istream_t *strm) } if (actual == 0) { - strm->eof = true; + file->eof = true; break; } diff --git a/lib/io/src/xfrm/istream.c b/lib/io/src/xfrm/istream.c index a89ac3d..2ada5db 100644 --- a/lib/io/src/xfrm/istream.c +++ b/lib/io/src/xfrm/istream.c @@ -20,9 +20,6 @@ static int xfrm_precache(istream_t *base) istream_xfrm_t *xfrm = (istream_xfrm_t *)base; int ret, sret; - if (base->eof) - return 0; - assert(base->buffer >= xfrm->uncompressed); assert(base->buffer <= (xfrm->uncompressed + BUFSZ)); assert(base->buffer_used <= BUFSZ); @@ -73,11 +70,8 @@ static int xfrm_precache(istream_t *base) if (ret == XFRM_STREAM_BUFFER_FULL || out_off >= BUFSZ) break; - if (mode == XFRM_STREAM_FLUSH_FULL) { - if (base->buffer_used == 0) - base->eof = true; + if (mode == XFRM_STREAM_FLUSH_FULL) break; - } } return 0; @@ -115,7 +109,6 @@ istream_t *istream_xfrm_create(istream_t *strm, xfrm_stream_t *xfrm) base->precache = xfrm_precache; base->get_filename = xfrm_get_filename; base->buffer = stream->uncompressed; - base->eof = false; return base; fail: fprintf(stderr, "%s: error initializing decompressor stream.\n", |