diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2023-06-04 14:36:25 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2023-06-04 15:09:05 +0200 |
commit | 723306c417b3b0f8e6a3904906d6c5612cace432 (patch) | |
tree | 34235c4e6e11a1702e61d81f4f58bc9f3da57c58 /lib/io/src/istream.c | |
parent | 061fbc12fe49ff49088a644def3227d3800cd8a7 (diff) |
libio: Move istream_t precache logic into backend implementation
The end goal is to remove direct buffer access from the istream_t
interfaces and make that opaque. For the tar implementation, this
already safes us needless buffer copying, as we essentially allow
the user to read-through from the underlying stream.
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib/io/src/istream.c')
-rw-r--r-- | lib/io/src/istream.c | 20 |
1 files changed, 0 insertions, 20 deletions
diff --git a/lib/io/src/istream.c b/lib/io/src/istream.c index 64fa478..051fac8 100644 --- a/lib/io/src/istream.c +++ b/lib/io/src/istream.c @@ -38,26 +38,6 @@ sqfs_s32 istream_read(istream_t *strm, void *data, size_t size) return total; } -int istream_precache(istream_t *strm) -{ - if (strm->buffer_offset >= strm->buffer_used) { - strm->buffer_offset = 0; - strm->buffer_used = 0; - } else if (strm->buffer_offset > 0) { - memmove(strm->buffer, - strm->buffer + strm->buffer_offset, - strm->buffer_used - strm->buffer_offset); - - strm->buffer_used -= strm->buffer_offset; - strm->buffer_offset = 0; - } - - if (strm->eof) - return 0; - - return strm->precache(strm); -} - int istream_skip(istream_t *strm, sqfs_u64 size) { size_t diff; |