Read-only partition on a stream object. More...

#include <StreamDevice.h>

Inheritance diagram for Storage::StreamDevice:
[legend]
Collaboration diagram for Storage::StreamDevice:
[legend]

Public Member Functions

 StreamDevice (IDataSourceStream *stream, size_t size)
 
 StreamDevice (IDataSourceStream *stream)
 
Type getType () const override
 Obtain device type. More...
 
bool read (uint32_t address, void *buffer, size_t len) override
 Read data from the storage device. More...
 
bool write (uint32_t address, const void *data, size_t len) override
 Write data to the storage device. More...
 
bool erase_range (uint32_t address, size_t len) override
 Erase a region of storage in preparation for writing. More...
 
- Public Member Functions inherited from Storage::CustomDevice
Partition createPartition (const Partition::Info &info)
 
Partition createPartition (const String &name, Partition::Type type, uint8_t subtype, uint32_t offset, size_t size, Partition::Flags flags=0)
 
template<typename SubType >
Partition createPartition (const String &name, SubType subtype, uint32_t offset, size_t size, Partition::Flags flags=0)
 
- Public Member Functions inherited from Storage::Device
 Device ()
 
 ~Device ()
 
bool operator== (const String &name) const
 
PartitionTablepartitions ()
 
const PartitionTablepartitions () const
 
bool loadPartitions (uint32_t tableOffset)
 Load partition table entries Location of partition table to read. More...
 
bool loadPartitions (Device &source, uint32_t tableOffset)
 Load partition table entries from another table. More...
 
virtual String getName () const =0
 Obtain unique device name. More...
 
virtual uint32_t getId () const
 Obtain device ID. More...
 
virtual size_t getBlockSize () const =0
 Obtain smallest allocation unit for erase operations. More...
 
virtual size_t getSize () const =0
 Obtain addressable size of this device. More...
 
- Public Member Functions inherited from LinkedObjectTemplate< Device >
Device * getNext () const
 
Iterator begin () const
 
Iterator end () const
 
Iterator cbegin () const
 
Iterator cend () const
 
- Public Member Functions inherited from LinkedObject
virtual ~LinkedObject ()
 
virtual LinkedObjectnext () const
 
LinkedObjectgetNext () const
 
bool operator== (const LinkedObject &other) const
 
bool operator!= (const LinkedObject &other) const
 

Static Public Member Functions

static String nameOf (IDataSourceStream *stream)
 

Additional Inherited Members

- Public Types inherited from Storage::Device
enum  Type : uint8_t { Type::XX }
 Storage type. More...
 
using List = LinkedObjectListTemplate< Device >
 
using OwnedList = OwnedLinkedObjectListTemplate< Device >
 
- Public Types inherited from LinkedObjectTemplate< Device >
using Iterator = IteratorTemplate< Device, Device *, Device &>
 
using ConstIterator = IteratorTemplate< const Device, const Device *, const Device &>
 
- Protected Attributes inherited from Storage::Device
PartitionTable mPartitions
 

Detailed Description

Read-only partition on a stream object.

Note
Writes not possible as streams always append data, cannot do random writes

Constructor & Destructor Documentation

◆ StreamDevice() [1/2]

Storage::StreamDevice::StreamDevice ( IDataSourceStream stream,
size_t  size 
)
inline

◆ StreamDevice() [2/2]

Storage::StreamDevice::StreamDevice ( IDataSourceStream stream)
inline

Member Function Documentation

◆ erase_range()

bool Storage::StreamDevice::erase_range ( uint32_t  address,
size_t  size 
)
inlineoverridevirtual

Erase a region of storage in preparation for writing.

Parameters
addressWhere to start erasing
sizeSize of region to erase, in bytes
Return values
booltrue on success, false on error

Implements Storage::Device.

◆ getType()

Type Storage::StreamDevice::getType ( ) const
inlineoverridevirtual

Obtain device type.

Implements Storage::Device.

◆ nameOf()

static String Storage::StreamDevice::nameOf ( IDataSourceStream stream)
inlinestatic

◆ read()

bool Storage::StreamDevice::read ( uint32_t  address,
void *  dst,
size_t  size 
)
inlineoverridevirtual

Read data from the storage device.

Parameters
addressWhere to start reading
dstBuffer to store data
sizeSize of data to be read, in bytes.
Return values
booltrue on success, false on error

Implements Storage::Device.

◆ write()

bool Storage::StreamDevice::write ( uint32_t  address,
const void *  src,
size_t  size 
)
inlineoverridevirtual

Write data to the storage device.

Parameters
addressWhere to start writing
srcData to write
sizeSize of data to be written, in bytes.
Return values
booltrue on success, false on error

Implements Storage::Device.


The documentation for this class was generated from the following file: