blob: ea4256ac7c10206a7184cd6a6eeacb0123342b31 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
#pragma once
#include <cstdint>
namespace audio {
extern const std::size_t kMaxFrameSize;
class IAudioElement {
public:
virtual ~IAudioElement();
enum CommandType {
/*
* Sets the sequence number of the most recent byte stream. Any commands
* received that have a lower sequence number than this will be discarded.
*/
SEQUENCE_NUMBER,
/*
* Instructs this element to read a specific number of bytes from its
* input buffer.
*/
READ_FRAME,
/*
* Represents an element-specific command. This handling of this is
* delegated to element implementations.
*/
ELEMENT,
/* Instructs this element to shut down. */
QUIT,
};
struct Command {
CommandType type;
uint8_t sequence_number;
union {
void* data;
std::size_t frame_size;
};
};
/*
* Returns a queue that should be used for all communication with this
* element.
*/
virtual auto InputCommandQueue() -> QueueHandle_t = 0;
/*
* Returns a buffer that will be used to stream input bytes to this element.
* This may be NULL, if this element represents a source, e.g. a FATFS
* reader.
*/
virtual auto InputBuffer() -> StreamBufferHandle_t = 0;
/*
* Called when an element-specific command has been received.
*/
virtual auto ProcessElementCommand(void* command) -> void = 0;
virtual auto SkipElementCommand(void* command) -> void = 0;
/*
* Called with the result of a read bytes command.
*/
virtual auto ProcessData(uint8_t* data, uint16_t length) -> void = 0;
/*
* Called periodically when there are no pending commands.
*/
virtual auto ProcessIdle() -> void = 0;
};
} // namespace audio
|