aboutsummaryrefslogtreecommitdiff
path: root/include/cru/common/io
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-01-15 18:34:55 +0800
committercrupest <crupest@outlook.com>2022-01-15 18:34:55 +0800
commit76b631144e008006efb3894c16e6fd04608d0b68 (patch)
treef676581ac216e910124dd42bd748d9f4a963217a /include/cru/common/io
parentae638fc0c2cad09ae0ab69707852588aedc6e0df (diff)
downloadcru-76b631144e008006efb3894c16e6fd04608d0b68.tar.gz
cru-76b631144e008006efb3894c16e6fd04608d0b68.tar.bz2
cru-76b631144e008006efb3894c16e6fd04608d0b68.zip
...
Diffstat (limited to 'include/cru/common/io')
-rw-r--r--include/cru/common/io/Stream.hpp2
-rw-r--r--include/cru/common/io/UnixFileStream.hpp41
2 files changed, 43 insertions, 0 deletions
diff --git a/include/cru/common/io/Stream.hpp b/include/cru/common/io/Stream.hpp
index e13e5388..5fa307ed 100644
--- a/include/cru/common/io/Stream.hpp
+++ b/include/cru/common/io/Stream.hpp
@@ -32,5 +32,7 @@ class CRU_BASE_API Stream : public Object {
virtual Index Write(const std::byte* buffer, Index size);
virtual void Flush() = 0;
+
+ virtual void Close();
};
} // namespace cru::io
diff --git a/include/cru/common/io/UnixFileStream.hpp b/include/cru/common/io/UnixFileStream.hpp
new file mode 100644
index 00000000..c8c3fe52
--- /dev/null
+++ b/include/cru/common/io/UnixFileStream.hpp
@@ -0,0 +1,41 @@
+#pragma once
+
+#include "../String.hpp"
+#include "OpenFileFlag.hpp"
+#include "Stream.hpp"
+
+namespace cru::io {
+class UnixFileStream : public Stream {
+ public:
+ UnixFileStream(String path, OpenFileFlag flags);
+
+ CRU_DELETE_COPY(UnixFileStream)
+ CRU_DELETE_MOVE(UnixFileStream)
+
+ ~UnixFileStream() override;
+
+ public:
+ bool CanSeek() override;
+ Index Tell() override;
+ void Seek(Index offset, SeekOrigin origin = SeekOrigin::Current) override;
+
+ bool CanRead() override;
+ Index Read(std::byte* buffer, Index offset, Index size) override;
+
+ bool CanWrite() override;
+ Index Write(const std::byte* buffer, Index offset, Index size) override;
+
+ void Flush() override;
+
+ void Close() override;
+
+ private:
+ void CheckClosed();
+
+ private:
+ String path_;
+ OpenFileFlag flags;
+ int file_descriptor_;
+ bool closed_ = false;
+};
+} // namespace cru::io