|
CeresEngine 0.2.0
A game development framework
|
A data stream that reads or writes data into a file. More...
#include <CeresEngine/Foundation/IO/Stream.hpp>
Public Member Functions | |
| FileDataStream (const FilePath &path, bool writing=false) | |
Creates a new file stream by opening the file at the given path. | |
| FileDataStream (const FileDataStream &other) | |
Creates a new file data stream by opening the same file as other. | |
| FileDataStream (FileDataStream &&other) noexcept | |
Creates a new file data stream by moving the already open stream other. | |
| ~FileDataStream () final | |
| Destroys the data stream and closes the file. | |
| const FilePath & | getPath () const noexcept |
| The path to the file open in the stream. | |
| FILE * | getStream () const noexcept |
| The open stream descriptor. | |
| bool | isSeekable (Seek mode=Seek::Start) const noexcept final |
| Checks if the stream is seekable. | |
| void | seek (std::streamsize position, Seek mode=Seek::Start) final |
| Changes the position of the data stream. | |
| bool | isTellable () const noexcept final |
| Checks if the stream knows it's current absolute position. | |
| size_t | tell () final |
| Gets the absolute stream position, in bytes. | |
| bool | isSizeKnown () const noexcept final |
| Checks if the stream knows the size of the data. | |
| size_t | size () final |
| Gets the number of bytes available on the stream. | |
| bool | isReadable () const noexcept final |
| Checks if the stream is readable. | |
| size_t | read (void *data, size_t n) final |
Reads data from the data stream to a buffer of raw memory data with length n. | |
| bool | isWritable () const noexcept final |
| Checks if the stream is writable. | |
| size_t | write (const void *data, size_t n) final |
Writes data to the data stream from a buffer of raw memory data with length n. | |
Public Member Functions inherited from CeresEngine::IInputStream | |
| template<typename T > | |
| size_t | read (const MemoryView< T > &memoryView) |
| Reads data from the strea into a memory view. | |
| template<typename T > | |
| size_t | read (const StridedMemoryView< T > &memoryView) |
| Reads data from the stream into a strided memory view. | |
| Optional< String > | readString () |
Reads data from the buffer as a C++ String. | |
| template<typename T > requires std::is_trivially_copyable_v<T> | |
| Optional< T > | read () |
| Reads a trivially copyable obhect from the stream. | |
| virtual bool | invalidate () |
| In the stream is buffered, invalidates any buffered read data from the stream. | |
Public Member Functions inherited from CeresEngine::IStream | |
| IStream ()=default | |
| IStream (const IStream &) noexcept=delete | |
| IStream & | operator= (const IStream &) noexcept=delete |
| IStream (IStream &&) noexcept=default | |
| IStream & | operator= (IStream &&) noexcept=default |
| virtual | ~IStream () noexcept=default |
| void | skip (const size_t n) |
Skips n bytes from the data stream. | |
Public Member Functions inherited from CeresEngine::IOutputStream | |
| template<typename T > | |
| size_t | write (const MemoryView< const T > &memoryView) |
| Writes data from a memory view to the stream. | |
| template<typename T > | |
| size_t | write (const StridedMemoryView< const T > &memoryView) |
| Writes data from a strided memory view to the stream. | |
| size_t | writeString (const StringView string) |
| Writes a string to the data stream. | |
| template<typename T > requires std::is_trivially_copyable_v<T> | |
| bool | write (T value) |
| Writes a trivially copyable object to the stream. | |
| virtual bool | flush () |
| In the stream is buffered, invalidates any buffered write data from to stream. | |
Private Attributes | |
| FilePath | path |
| The path to the file open in the stream. | |
| FILE * | stream = nullptr |
| The open stream descriptor. | |
Additional Inherited Members | |
Public Types inherited from CeresEngine::IStream | |
| enum class | Seek { Start = SEEK_SET , Current = SEEK_CUR , End = SEEK_END } |
| An enumeration that describes how a data stream should be seeked. More... | |
A data stream that reads or writes data into a file.
|
explicit |
Creates a new file stream by opening the file at the given path.
| path | The file path to be open |
| CeresEngine::FileDataStream::FileDataStream | ( | const FileDataStream & | other | ) |
Creates a new file data stream by opening the same file as other.
| other | The stream to open the same file as |
|
noexcept |
Creates a new file data stream by moving the already open stream other.
| other | The stream to be moved |
|
final |
Destroys the data stream and closes the file.
The path to the file open in the stream.
|
inlinenoexcept |
The open stream descriptor.
|
inlinefinalvirtualnoexcept |
Checks if the stream is readable.
If this method returns true, read() is safe to be called on this stream.
Reimplemented from CeresEngine::IInputStream.
|
inlinefinalvirtualnoexcept |
Checks if the stream is seekable.
If this method returns true, seek() is safe to be called on this stream.
Reimplemented from CeresEngine::IStream.
|
inlinefinalvirtualnoexcept |
Checks if the stream knows the size of the data.
If this method returns true, size() is safe to be called on this stream.
Reimplemented from CeresEngine::IStream.
|
inlinefinalvirtualnoexcept |
Checks if the stream knows it's current absolute position.
If this method returns true, tell() is safe to be called on this stream.
Reimplemented from CeresEngine::IStream.
|
inlinefinalvirtualnoexcept |
Checks if the stream is writable.
If this method returns true, write() is safe to be called on this stream.
Reimplemented from CeresEngine::IOutputStream.
Reads data from the data stream to a buffer of raw memory data with length n.
isReadable() returns true.| data | The memory location to which read data should be placed. |
| n | The maximum number of bytes to be read from the data stream. |
n. If 0, indicates that the stream has ended. Reimplemented from CeresEngine::IInputStream.
|
finalvirtual |
Changes the position of the data stream.
isSeekable() returns true.| position | The position to set the data stream to. |
| mode | The mode to change the data stream position. |
Reimplemented from CeresEngine::IStream.
|
finalvirtual |
Gets the number of bytes available on the stream.
isSizeKnown() returns true. Reimplemented from CeresEngine::IStream.
|
finalvirtual |
Gets the absolute stream position, in bytes.
isTellable() returns true. Reimplemented from CeresEngine::IStream.
Writes data to the data stream from a buffer of raw memory data with length n.
isWritable() returns true.| data | The memory location to which written data should be copied from. |
| n | The maximum number of bytes to be write to the data stream. |
n, in that case the write operation must be repeated to ensure that all data was written. If 0, indicates that the stream has ended. Reimplemented from CeresEngine::IOutputStream.
|
private |
The path to the file open in the stream.