diff options
Diffstat (limited to 'src/audio/chunk.cpp')
| -rw-r--r-- | src/audio/chunk.cpp | 71 |
1 files changed, 0 insertions, 71 deletions
diff --git a/src/audio/chunk.cpp b/src/audio/chunk.cpp deleted file mode 100644 index 11503b2b..00000000 --- a/src/audio/chunk.cpp +++ /dev/null @@ -1,71 +0,0 @@ -/* - * Copyright 2023 jacqueline <me@jacqueline.id.au> - * - * SPDX-License-Identifier: GPL-3.0-only - */ - -#include "chunk.hpp" - -#include <algorithm> -#include <cstddef> -#include <cstdint> -#include <cstring> -#include <optional> - -#include "cbor.h" -#include "esp_log.h" - -#include "stream_buffer.hpp" -#include "stream_message.hpp" - -namespace audio { - -static const std::size_t kWorkingBufferMultiple = 2; - -ChunkReader::ChunkReader(std::size_t chunk_size) - : raw_working_buffer_(static_cast<std::byte*>( - heap_caps_malloc(chunk_size * kWorkingBufferMultiple, - MALLOC_CAP_SPIRAM))), - working_buffer_(raw_working_buffer_, - chunk_size * kWorkingBufferMultiple) {} - -ChunkReader::~ChunkReader() { - free(raw_working_buffer_); -} - -auto ChunkReader::HandleNewData(cpp::span<std::byte> data) - -> cpp::span<std::byte> { - assert(leftover_bytes_ + data.size() <= working_buffer_.size()); - // Copy the new data onto the front for anything that was left over from the - // last portion. Note: this could be optimised for the '0 leftover bytes' - // case, which technically shouldn't need a copy. - std::copy(data.begin(), data.end(), - working_buffer_.begin() + leftover_bytes_); - last_data_in_working_buffer_ = - working_buffer_.first(leftover_bytes_ + data.size()); - leftover_bytes_ = 0; - return last_data_in_working_buffer_; -} - -auto ChunkReader::HandleBytesUsed(std::size_t bytes_used) -> void { - HandleBytesLeftOver(last_data_in_working_buffer_.size() - bytes_used); -} -auto ChunkReader::HandleBytesLeftOver(std::size_t bytes_left) -> void { - leftover_bytes_ = bytes_left; - - // Ensure that we don't have more than a chunk of leftever bytes. This is - // bad, because we probably won't have enough data to store the next chunk. - assert(leftover_bytes_ <= working_buffer_.size() / kWorkingBufferMultiple); - - if (leftover_bytes_ > 0) { - auto data_to_keep = last_data_in_working_buffer_.last(leftover_bytes_); - std::copy(data_to_keep.begin(), data_to_keep.end(), - working_buffer_.begin()); - } -} - -auto ChunkReader::GetLeftovers() -> cpp::span<std::byte> { - return working_buffer_.first(leftover_bytes_); -} - -} // namespace audio |
