summaryrefslogtreecommitdiff
path: root/src/codecs/include/codec.hpp
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2023-08-10 15:33:00 +1000
committerjacqueline <me@jacqueline.id.au>2023-08-10 15:33:00 +1000
commitd8fc77101dcf80a3643a00b3446dca1e390ce997 (patch)
tree9e03881f3857c7b4c6a0b6e3a062947daecc69d1 /src/codecs/include/codec.hpp
parent67caeb6e3cda44205ba8fe783274b20dc7ea216e (diff)
downloadtangara-fw-d8fc77101dcf80a3643a00b3446dca1e390ce997.tar.gz
Give codecs complete control of their input files
Diffstat (limited to 'src/codecs/include/codec.hpp')
-rw-r--r--src/codecs/include/codec.hpp46
1 files changed, 36 insertions, 10 deletions
diff --git a/src/codecs/include/codec.hpp b/src/codecs/include/codec.hpp
index 32ebef69..ece3d4fe 100644
--- a/src/codecs/include/codec.hpp
+++ b/src/codecs/include/codec.hpp
@@ -24,6 +24,34 @@
namespace codecs {
/*
+ * Interface for an abstract source of file-like data.
+ */
+class IStream {
+ public:
+ IStream(StreamType t) : t_(t) {}
+ virtual ~IStream() {}
+
+ auto type() -> StreamType { return t_; }
+
+ virtual auto Read(cpp::span<std::byte> dest) -> ssize_t = 0;
+
+ virtual auto CanSeek() -> bool = 0;
+
+ enum class SeekFrom {
+ kStartOfStream,
+ kEndOfStream,
+ kCurrentPosition,
+ };
+
+ virtual auto SeekTo(int64_t destination, SeekFrom from) -> void = 0;
+
+ virtual auto CurrentPosition() -> int64_t = 0;
+
+ protected:
+ StreamType t_;
+};
+
+/*
* Common interface to be implemented by all audio decoders.
*/
class ICodec {
@@ -63,32 +91,30 @@ class ICodec {
struct OutputFormat {
uint8_t num_channels;
uint32_t sample_rate_hz;
-
std::optional<uint32_t> duration_seconds;
- std::optional<uint32_t> bits_per_second;
+
+ bool operator==(const OutputFormat&) const = default;
};
/*
* Decodes metadata or headers from the given input stream, and returns the
* format for the samples that will be decoded from it.
*/
- virtual auto BeginStream(cpp::span<const std::byte> input)
- -> Result<OutputFormat> = 0;
+ virtual auto OpenStream(std::shared_ptr<IStream> input)
+ -> cpp::result<OutputFormat, Error> = 0;
struct OutputInfo {
std::size_t samples_written;
- bool is_finished_writing;
+ bool is_stream_finished;
};
/*
* Writes PCM samples to the given output buffer.
*/
- virtual auto ContinueStream(cpp::span<const std::byte> input,
- cpp::span<sample::Sample> output)
- -> Result<OutputInfo> = 0;
+ virtual auto DecodeTo(cpp::span<sample::Sample> destination)
+ -> cpp::result<OutputInfo, Error> = 0;
- virtual auto SeekStream(cpp::span<const std::byte> input,
- std::size_t target_sample) -> Result<void> = 0;
+ virtual auto SeekTo(size_t target_sample) -> cpp::result<void, Error> = 0;
};
auto CreateCodecForType(StreamType type) -> std::optional<ICodec*>;