13#include <freertos/FreeRTOS.h>
98 static std::unique_ptr<AudioSinkTransferBuffer>
create(
size_t buffer_size);
139 virtual const uint8_t *
data()
const = 0;
145 virtual size_t free()
const {
return 0; }
158 virtual size_t fill(TickType_t ticks_to_wait,
bool pre_shift) {
return 0; }
159 size_t fill(TickType_t ticks_to_wait) {
return this->
fill(ticks_to_wait,
true); }
172 static std::unique_ptr<AudioSourceTransferBuffer>
create(
size_t buffer_size);
188 size_t free()
const override;
191 size_t fill(TickType_t ticks_to_wait,
bool pre_shift)
override {
208 void consume(
size_t bytes)
override;
Abstract interface for reading audio data from a buffer.
virtual const uint8_t * data() const =0
Returns a pointer to the start of readable data.
virtual size_t fill(TickType_t ticks_to_wait, bool pre_shift)
Refills the buffer from its source.
virtual size_t available() const =0
Returns the number of bytes available to read.
virtual size_t free() const
Returns the number of free bytes available to write. Defaults to 0 for read-only buffers.
virtual ~AudioReadableBuffer()=default
size_t fill(TickType_t ticks_to_wait)
virtual bool has_buffered_data() const =0
Tests if there is any buffered data.
virtual void consume(size_t bytes)=0
Advances past consumed data.
Abstract interface for writing decoded audio data to a sink.
virtual size_t audio_sink_write(uint8_t *data, size_t length, TickType_t ticks_to_wait)=0
size_t transfer_data_to_sink(TickType_t ticks_to_wait, bool post_shift=true)
Writes any available data in the transfer buffer to the sink.
void set_sink(const std::weak_ptr< RingBuffer > &ring_buffer)
Adds a ring buffer as the transfer buffer's sink.
void set_sink(AudioSinkCallback *callback)
Adds a callback as the transfer buffer's sink.
void clear_buffered_data() override
AudioSinkCallback * sink_callback_
void set_sink(speaker::Speaker *speaker)
Adds a speaker as the transfer buffer's sink.
bool has_buffered_data() const override
speaker::Speaker * speaker_
static std::unique_ptr< AudioSinkTransferBuffer > create(size_t buffer_size)
Creates a new sink transfer buffer.
size_t fill(TickType_t ticks_to_wait, bool pre_shift) override
const uint8_t * data() const override
size_t transfer_data_from_source(TickType_t ticks_to_wait, bool pre_shift=true)
Reads any available data from the source into the transfer buffer.
static std::unique_ptr< AudioSourceTransferBuffer > create(size_t buffer_size)
Creates a new source transfer buffer.
void consume(size_t bytes) override
void set_source(const std::weak_ptr< RingBuffer > &ring_buffer)
Adds a ring buffer as the transfer buffer's source.
size_t free() const override
size_t available() const override
bool has_buffered_data() const override
size_t free() const
Returns the transfer buffer's currrently free bytes available to write.
virtual bool has_buffered_data() const
Tests if there is any data in the tranfer buffer or the source/sink.
virtual void clear_buffered_data()
Clears data in the transfer buffer and, if possible, the source/sink.
~AudioTransferBuffer()
Destructor that deallocates the transfer buffer.
uint8_t * get_buffer_end() const
Returns a pointer to the end of the transfer buffer where free() bytes of new data can be written.
void increase_buffer_length(size_t bytes)
Updates the internal state of the transfer buffer.
bool reallocate(size_t new_buffer_size)
Reallocates the transfer buffer, preserving any existing data.
bool allocate_buffer_(size_t buffer_size)
Allocates the transfer buffer in external memory, if available.
uint8_t * get_buffer_start() const
Returns a pointer to the start of the transfer buffer where available() bytes of existing data can be...
void decrease_buffer_length(size_t bytes)
Updates the internal state of the transfer buffer.
size_t available() const
Returns the transfer buffer's currently available bytes to read.
std::shared_ptr< RingBuffer > ring_buffer_
size_t capacity() const
Returns the transfer buffers allocated bytes.
void deallocate_buffer_()
Deallocates the buffer and resets the class variables.
A lightweight read-only audio buffer for const data sources (e.g., flash memory).
size_t available() const override
bool has_buffered_data() const override
void set_data(const uint8_t *data, size_t length)
Sets the data pointer and length for the buffer.
const uint8_t * data_start_
const uint8_t * data() const override
void consume(size_t bytes) override
Providing packet encoding functions for exchanging data with a remote host.