summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2024-05-16 12:20:50 +1000
committerjacqueline <me@jacqueline.id.au>2024-05-16 12:20:50 +1000
commitc1f7adf22700a268ce16ebcdda49aee6e71b53ff (patch)
tree54505c4b9472de4dd490a925831eb8ec670a2d7b /src
parente8f5e73b1a83a4d4742d60fb8cbb3a5642c8c8d5 (diff)
downloadtangara-fw-c1f7adf22700a268ce16ebcdda49aee6e71b53ff.tar.gz
Add a 'decoder' for streams already in our native format
Diffstat (limited to 'src')
-rw-r--r--src/codecs/CMakeLists.txt2
-rw-r--r--src/codecs/codec.cpp5
-rw-r--r--src/codecs/include/native.hpp41
-rw-r--r--src/codecs/include/types.hpp3
-rw-r--r--src/codecs/native.cpp48
5 files changed, 97 insertions, 2 deletions
diff --git a/src/codecs/CMakeLists.txt b/src/codecs/CMakeLists.txt
index a1221adf..a6a48c84 100644
--- a/src/codecs/CMakeLists.txt
+++ b/src/codecs/CMakeLists.txt
@@ -4,7 +4,7 @@
idf_component_register(
SRCS "dr_flac.cpp" "codec.cpp" "mad.cpp" "opus.cpp" "vorbis.cpp"
- "source_buffer.cpp" "sample.cpp" "wav.cpp"
+ "source_buffer.cpp" "sample.cpp" "wav.cpp" "native.cpp"
INCLUDE_DIRS "include"
REQUIRES "result" "libmad" "drflac" "tremor" "opusfile" "memory" "util"
"komihash")
diff --git a/src/codecs/codec.cpp b/src/codecs/codec.cpp
index c8e1a72c..af5702ff 100644
--- a/src/codecs/codec.cpp
+++ b/src/codecs/codec.cpp
@@ -11,6 +11,7 @@
#include "dr_flac.hpp"
#include "mad.hpp"
+#include "native.hpp"
#include "opus.hpp"
#include "types.hpp"
#include "vorbis.hpp"
@@ -30,6 +31,8 @@ auto StreamTypeToString(StreamType t) -> std::string {
return "Flac";
case StreamType::kOpus:
return "Opus";
+ case StreamType::kNative:
+ return "Native";
default:
return "";
}
@@ -47,6 +50,8 @@ auto CreateCodecForType(StreamType type) -> std::optional<ICodec*> {
return new XiphOpusDecoder();
case StreamType::kWav:
return new WavDecoder();
+ case StreamType::kNative:
+ return new NativeDecoder();
default:
return {};
}
diff --git a/src/codecs/include/native.hpp b/src/codecs/include/native.hpp
new file mode 100644
index 00000000..8f544e13
--- /dev/null
+++ b/src/codecs/include/native.hpp
@@ -0,0 +1,41 @@
+/*
+ * Copyright 2023 jacqueline <me@jacqueline.id.au>
+ *
+ * SPDX-License-Identifier: GPL-3.0-only
+ */
+
+#pragma once
+
+#include <cstddef>
+#include <cstdint>
+#include <optional>
+#include <span>
+#include <string>
+#include <utility>
+
+#include "mad.h"
+#include "sample.hpp"
+#include "source_buffer.hpp"
+
+#include "codec.hpp"
+
+namespace codecs {
+
+class NativeDecoder : public ICodec {
+ public:
+ NativeDecoder();
+
+ auto OpenStream(std::shared_ptr<IStream> input, uint32_t offset)
+ -> cpp::result<OutputFormat, Error> override;
+
+ auto DecodeTo(std::span<sample::Sample> destination)
+ -> cpp::result<OutputInfo, Error> override;
+
+ NativeDecoder(const NativeDecoder&) = delete;
+ NativeDecoder& operator=(const NativeDecoder&) = delete;
+
+ private:
+ std::shared_ptr<IStream> input_;
+};
+
+} // namespace codecs
diff --git a/src/codecs/include/types.hpp b/src/codecs/include/types.hpp
index c6dcb486..2bc63b10 100644
--- a/src/codecs/include/types.hpp
+++ b/src/codecs/include/types.hpp
@@ -16,8 +16,9 @@ enum class StreamType {
kFlac,
kOpus,
kWav,
+ kNative,
};
auto StreamTypeToString(StreamType t) -> std::string;
-
+
} // namespace codecs
diff --git a/src/codecs/native.cpp b/src/codecs/native.cpp
new file mode 100644
index 00000000..124434e8
--- /dev/null
+++ b/src/codecs/native.cpp
@@ -0,0 +1,48 @@
+/*
+ * Copyright 2023 jacqueline <me@jacqueline.id.au>
+ *
+ * SPDX-License-Identifier: GPL-3.0-only
+ */
+
+#include "native.hpp"
+
+#include <cstdint>
+#include <cstring>
+#include <optional>
+
+#include "esp_heap_caps.h"
+#include "mad.h"
+
+#include "codec.hpp"
+#include "esp_log.h"
+#include "result.hpp"
+#include "sample.hpp"
+#include "types.hpp"
+
+namespace codecs {
+
+NativeDecoder::NativeDecoder() : input_() {}
+
+auto NativeDecoder::OpenStream(std::shared_ptr<IStream> input, uint32_t offset)
+ -> cpp::result<OutputFormat, ICodec::Error> {
+ input_ = input;
+ return OutputFormat{
+ .num_channels = 1,
+ .sample_rate_hz = 48000,
+ .total_samples = {},
+ };
+}
+
+auto NativeDecoder::DecodeTo(std::span<sample::Sample> output)
+ -> cpp::result<OutputInfo, Error> {
+ size_t bytes = input_->Read({
+ reinterpret_cast<std::byte*>(output.data()),
+ output.size_bytes(),
+ });
+ return OutputInfo{
+ .samples_written = bytes / sizeof(sample::Sample),
+ .is_stream_finished = false,
+ };
+}
+
+} // namespace codecs