aboutsummaryrefslogtreecommitdiff
path: root/include/cru/common/io/MemoryStream.h
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2024-06-24 00:06:25 +0800
committercrupest <crupest@outlook.com>2024-10-04 19:55:33 +0800
commitf51eb955e188858272230a990565931e7403f23b (patch)
tree04de484bfcd056b6eea56c13c42cce83315c448f /include/cru/common/io/MemoryStream.h
parent1b30150ab79ff1338f209a8ddb54b3dc60cfb599 (diff)
downloadcru-f51eb955e188858272230a990565931e7403f23b.tar.gz
cru-f51eb955e188858272230a990565931e7403f23b.tar.bz2
cru-f51eb955e188858272230a990565931e7403f23b.zip
HALF WORK: Stream refactor.
TODO: Complete refactor of BufferStream and AutoReadStream. NEED TEST: BufferStream, AutoReadStream, SubProcess.
Diffstat (limited to 'include/cru/common/io/MemoryStream.h')
-rw-r--r--include/cru/common/io/MemoryStream.h34
1 files changed, 13 insertions, 21 deletions
diff --git a/include/cru/common/io/MemoryStream.h b/include/cru/common/io/MemoryStream.h
index a6243d67..a1f90c3b 100644
--- a/include/cru/common/io/MemoryStream.h
+++ b/include/cru/common/io/MemoryStream.h
@@ -7,38 +7,30 @@
namespace cru::io {
class CRU_BASE_API MemoryStream : public Stream {
public:
- MemoryStream() = default;
MemoryStream(
std::byte* buffer, Index size, bool read_only = false,
- std::function<void(std::byte* buffer, Index size)> release_func = {})
- : buffer_(buffer),
- size_(size),
- read_only_(read_only),
- release_func_(std::move(release_func)) {}
-
- CRU_DELETE_COPY(MemoryStream)
- CRU_DELETE_MOVE(MemoryStream)
+ std::function<void(std::byte* buffer, Index size)> release_func = {});
~MemoryStream() override;
public:
- bool CanSeek() override;
- Index Seek(Index offset, SeekOrigin origin = SeekOrigin::Current) override;
+ void Close() override;
- bool CanRead() override;
- Index Read(std::byte* buffer, Index offset, Index size) override;
+ std::byte* GetBuffer() const { return buffer_; }
- bool CanWrite() override;
- Index Write(const std::byte* buffer, Index offset, Index size) override;
+ protected:
+ Index DoSeek(Index offset, SeekOrigin origin) override;
+ Index DoGetSize() override { return size_; }
+ Index DoRead(std::byte* buffer, Index offset, Index size) override;
+ Index DoWrite(const std::byte* buffer, Index offset, Index size) override;
- std::byte* GetBuffer() const { return buffer_; }
- Index GetSize() override { return size_; }
+ private:
+ void DoClose();
private:
- std::byte* buffer_ = nullptr;
- Index size_ = 0;
- Index position_ = 0;
- bool read_only_ = false;
+ std::byte* buffer_;
+ Index size_;
+ Index position_;
std::function<void(std::byte* buffer, Index size)> release_func_;
};
} // namespace cru::io