mirror of https://github.com/probonopd/MiniDexed
parent
32b3b57ca1
commit
507a336b02
@ -0,0 +1,48 @@ |
||||
//
|
||||
// midichunker.cpp
|
||||
//
|
||||
// MiniDexed - Dexed FM synthesizer for bare metal Raspberry Pi
|
||||
// Copyright (C) 2022-25 The MiniDexed Team
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
//
|
||||
|
||||
#include "midichunker.h" |
||||
#include <algorithm> |
||||
|
||||
MIDISysExChunker::MIDISysExChunker(const uint8_t* data, size_t length, size_t chunkSize) |
||||
: m_data(data), m_length(length), m_chunkSize(chunkSize), m_offset(0) {} |
||||
|
||||
bool MIDISysExChunker::hasNext() const { |
||||
return m_offset < m_length; |
||||
} |
||||
|
||||
std::vector<uint8_t> MIDISysExChunker::next() { |
||||
if (!hasNext()) return {}; |
||||
size_t remaining = m_length - m_offset; |
||||
size_t chunkLen = std::min(m_chunkSize, remaining); |
||||
// Only the last chunk should contain the final 0xF7
|
||||
if (m_offset + chunkLen >= m_length && m_data[m_length-1] == 0xF7) { |
||||
chunkLen = m_length - m_offset; |
||||
} else if (m_offset + chunkLen > 0 && m_data[m_offset + chunkLen - 1] == 0xF7) { |
||||
chunkLen--; |
||||
} |
||||
std::vector<uint8_t> chunk(m_data + m_offset, m_data + m_offset + chunkLen); |
||||
m_offset += chunkLen; |
||||
return chunk; |
||||
} |
||||
|
||||
void MIDISysExChunker::reset() { |
||||
m_offset = 0; |
||||
} |
@ -0,0 +1,37 @@ |
||||
//
|
||||
// midichunker.h
|
||||
//
|
||||
// MiniDexed - Dexed FM synthesizer for bare metal Raspberry Pi
|
||||
// Copyright (C) 2022-25 The MiniDexed Team
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
//
|
||||
|
||||
#pragma once |
||||
#include <cstddef> |
||||
#include <vector> |
||||
#include <cstdint> |
||||
|
||||
class MIDISysExChunker { |
||||
public: |
||||
MIDISysExChunker(const uint8_t* data, size_t length, size_t chunkSize = 256); |
||||
bool hasNext() const; |
||||
std::vector<uint8_t> next(); |
||||
void reset(); |
||||
private: |
||||
const uint8_t* m_data; |
||||
size_t m_length; |
||||
size_t m_chunkSize; |
||||
size_t m_offset; |
||||
}; |
Loading…
Reference in new issue