|
CeresEngine 0.2.0
A game development framework
|
A stream that provides read-only stream functionality. More...
#include <CeresEngine/Foundation/IO/Stream.hpp>
Public Member Functions | |
| virtual bool | isReadable () const noexcept |
| Checks if the stream is readable. | |
| virtual size_t | read (void *data, size_t n) |
Reads data from the data stream to a buffer of raw memory data with length n. | |
| 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 |
| virtual bool | isSeekable (Seek mode=Seek::Start) const noexcept |
| Checks if the stream is seekable. | |
| virtual void | seek (std::streamsize position, Seek mode=Seek::Start) |
| Changes the position of the data stream. | |
| void | skip (const size_t n) |
Skips n bytes from the data stream. | |
| virtual bool | isTellable () const noexcept |
| Checks if the stream knows it's current absolute position. | |
| virtual size_t | tell () |
| Gets the absolute stream position, in bytes. | |
| virtual bool | isSizeKnown () const noexcept |
| Checks if the stream knows the size of the data. | |
| virtual size_t | size () |
| Gets the number of bytes available on the stream. | |
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 stream that provides read-only stream functionality.
In the stream is buffered, invalidates any buffered read data from the stream.
Non-buffered streams are free to ignore this method.
Reimplemented in CeresEngine::BufferedInputStream, CeresEngine::BufferedDataStream, CeresEngine::FilteredInputStream, CeresEngine::FilteredDataStream, and CeresEngine::WrappedResourceInputStream.
Checks if the stream is readable.
If this method returns true, read() is safe to be called on this stream.
Reimplemented in CeresEngine::AsyncDataStreamAdapter, CeresEngine::FileDataStream, CeresEngine::MemoryDataStream, CeresEngine::PipeInputStream, CeresEngine::FilteredInputStream, CeresEngine::FilteredDataStream, CeresEngine::LimitedInputStream, and CeresEngine::WrappedResourceInputStream.
Reads a trivially copyable obhect from the stream.
| T | The type of object to be read. |
|
inline |
Reads data from the strea into a memory view.
| memoryView | The memory view to read data to. |
n. If 0, indicates that the stream has ended.
|
inline |
Reads data from the stream into a strided memory view.
Data is read sequentially from the stream, but is placed respecting the striding requirements of the view.
| memoryView | The memory view to read data to. |
n. If 0, indicates that the stream has ended. 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 in CeresEngine::FilteredInputStream, CeresEngine::FilteredDataStream, CeresEngine::WrappedResourceInputStream, CeresEngine::BufferedInputStream, CeresEngine::BufferedDataStream, CeresEngine::AsyncDataStreamAdapter, CeresEngine::FileDataStream, CeresEngine::MemoryDataStream, CeresEngine::PipeInputStream, and CeresEngine::LimitedInputStream.
Reads data from the buffer as a C++ String.