diff options
author | crupest <crupest@outlook.com> | 2023-10-05 22:02:25 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2023-10-05 22:02:25 +0800 |
commit | 1550828518ff4719db88f35e088207816866a073 (patch) | |
tree | 217e35f48f6c08152bc607d804ad78c0a292e3cd /include/cru | |
parent | 90feae14e708fbb0b313503a6e76cfbd77f94ce1 (diff) | |
download | cru-1550828518ff4719db88f35e088207816866a073.tar.gz cru-1550828518ff4719db88f35e088207816866a073.tar.bz2 cru-1550828518ff4719db88f35e088207816866a073.zip |
...
Diffstat (limited to 'include/cru')
-rw-r--r-- | include/cru/common/io/CFileStream.h | 2 | ||||
-rw-r--r-- | include/cru/common/io/FileNotExistException.h | 19 | ||||
-rw-r--r-- | include/cru/common/io/FileStream.h | 46 | ||||
-rw-r--r-- | include/cru/common/io/Stream.h | 2 | ||||
-rw-r--r-- | include/cru/common/platform/unix/UnixFileStream.h | 5 |
5 files changed, 8 insertions, 66 deletions
diff --git a/include/cru/common/io/CFileStream.h b/include/cru/common/io/CFileStream.h index 65de2ac7..be23ac4a 100644 --- a/include/cru/common/io/CFileStream.h +++ b/include/cru/common/io/CFileStream.h @@ -24,9 +24,11 @@ class CRU_BASE_API CFileStream : public Stream { bool CanRead() override; Index Read(std::byte* buffer, Index offset, Index size) override; + using Stream::Read; bool CanWrite() override; Index Write(const std::byte* buffer, Index offset, Index size) override; + using Stream::Write; void Flush() override; diff --git a/include/cru/common/io/FileNotExistException.h b/include/cru/common/io/FileNotExistException.h deleted file mode 100644 index f49271b1..00000000 --- a/include/cru/common/io/FileNotExistException.h +++ /dev/null @@ -1,19 +0,0 @@ -#pragma once - -#include "../Base.h" -#include "../Exception.h" - -namespace cru::io { - class CRU_BASE_API FileNotExistException : public Exception { - public: - FileNotExistException(String path); - - CRU_DEFAULT_COPY(FileNotExistException) - CRU_DEFAULT_MOVE(FileNotExistException) - - ~FileNotExistException() override = default; - - private: - String path_; - }; -} diff --git a/include/cru/common/io/FileStream.h b/include/cru/common/io/FileStream.h deleted file mode 100644 index 4eab612f..00000000 --- a/include/cru/common/io/FileStream.h +++ /dev/null @@ -1,46 +0,0 @@ -/** - * Here are some notes about FileStream: - * - * 1. FileStream is currently implemented as a typedef of the corresponding - * specific XxxFileStream class implemented on each platform and controlled with - * preprocessor commands. There might be some other ways like proxy pattern but - * I do this way for simplicity. So your duty to implement a new platform is to - * define a new class and ensure it implements all the required interface. And - * in this way you are free to expose any other additional interface like for - * specific platform. - * - * 2. Since each platform defines their own way to open a file, especially the - * flags to open a file, we have to define a common interface. I decide to - * mimic Linux flags so on platforms where there is no direct support on certain - * flags we try our best to simulate it and make a note for users. - * - * (TODO: Currently the problem is that when I implemented for Windows and UNIX - * I didn't take this into consideration so I have to fix this inconsistency - * later.) - * - * The requirement of FileStream: - * 1. It must be derived from Stream, of course. - * 2. It must have a constructor FileStream(String path, io::OpenFlag flags), so - * user can construct one with the same interface. - */ - -#pragma once - -#include "../PreConfig.h" - -#ifdef CRU_PLATFORM_UNIX -#include "../platform/unix/UnixFileStream.h" -namespace cru::io { -using FileStream = platform::unix::UnixFileStream; -} -#elif CRU_PLATFORM_WINDOWS -#include "../platform/win/Win32FileStream.h" -namespace cru::io { -using FileStream = platform::win::Win32FileStream; -} -#elif CRU_PLATFORM_EMSCRIPTEN -#include "../platform/web/WebFileStream.h" -namespace cru::io { -using FileStream = platform::web::WebFileStream; -} -#endif diff --git a/include/cru/common/io/Stream.h b/include/cru/common/io/Stream.h index 2388874e..d24931da 100644 --- a/include/cru/common/io/Stream.h +++ b/include/cru/common/io/Stream.h @@ -32,7 +32,7 @@ class CRU_BASE_API StreamOperationNotSupportedException : public Exception { class CRU_BASE_API StreamAlreadyClosedException : public Exception { public: - using Exception::Exception; + StreamAlreadyClosedException(); CRU_DEFAULT_COPY(StreamAlreadyClosedException) CRU_DEFAULT_MOVE(StreamAlreadyClosedException) diff --git a/include/cru/common/platform/unix/UnixFileStream.h b/include/cru/common/platform/unix/UnixFileStream.h index bf13358b..4b86649e 100644 --- a/include/cru/common/platform/unix/UnixFileStream.h +++ b/include/cru/common/platform/unix/UnixFileStream.h @@ -8,6 +8,9 @@ namespace cru::platform::unix { class UnixFileStream : public io::Stream { + private: + static constexpr auto kLogTag = u"cru::platform::unix::UnixFileStream"; + public: UnixFileStream(const char* path, int oflag); UnixFileStream(int fd, bool can_seek, bool can_read, bool can_write, @@ -32,6 +35,8 @@ class UnixFileStream : public io::Stream { void Close() override; + int GetFileDescriptor() const { return file_descriptor_; } + private: void CheckClosed(); |