26 namespace MidiBufferHelpers
28 inline int getEventTime (
const void* d) noexcept
30 return readUnaligned<int32> (d);
33 inline uint16 getEventDataSize (
const void* d) noexcept
35 return readUnaligned<uint16> (
static_cast<const char*
> (d) +
sizeof (int32));
38 inline uint16 getEventTotalSize (
const void* d) noexcept
40 return (uint16) (getEventDataSize (d) +
sizeof (int32) +
sizeof (uint16));
43 static int findActualEventLength (
const uint8* data,
int maxBytes) noexcept
45 auto byte = (
unsigned int) *data;
47 if (
byte == 0xf0 ||
byte == 0xf7)
52 if (data[i++] == 0xf7)
65 return jmin (maxBytes, n + 2 + bytesLeft);
74 static uint8* findEventAfter (uint8* d, uint8* endData,
int samplePosition) noexcept
76 while (d < endData && getEventTime (d) <= samplePosition)
77 d += getEventTotalSize (d);
97 addEvent (message, 0);
107 auto start = MidiBufferHelpers::findEventAfter (
data.
begin(),
data.
end(), startSample - 1);
108 auto end = MidiBufferHelpers::findEventAfter (start,
data.
end(), startSample + numSamples - 1);
120 auto numBytes = MidiBufferHelpers::findActualEventLength (
static_cast<const uint8*
> (newData), maxBytes);
124 auto newItemSize = (size_t) numBytes +
sizeof (int32) +
sizeof (uint16);
130 writeUnaligned<int32> (d, sampleNumber);
132 writeUnaligned<uint16> (d,
static_cast<uint16
> (numBytes));
133 d +=
sizeof (uint16);
134 memcpy (d, newData, (
size_t) numBytes);
139 int startSample,
int numSamples,
int sampleDeltaToAdd)
144 const uint8* eventData;
145 int eventSize, position;
148 && (position < startSample + numSamples || numSamples < 0))
150 addEvent (eventData, eventSize, position + sampleDeltaToAdd);
159 for (
auto d =
data.
begin(); d < end; ++n)
160 d += MidiBufferHelpers::getEventTotalSize (d);
179 auto nextOne = d + MidiBufferHelpers::getEventTotalSize (d);
181 if (nextOne >= endData)
182 return MidiBufferHelpers::getEventTime (d);
190 : buffer (b), data (b.data.begin())
199 auto dataEnd = buffer.data.end();
201 while (
data < dataEnd && MidiBufferHelpers::getEventTime (
data) < samplePosition)
202 data += MidiBufferHelpers::getEventTotalSize (
data);
210 samplePosition = MidiBufferHelpers::getEventTime (
data);
211 auto itemSize = MidiBufferHelpers::getEventDataSize (
data);
213 midiData =
data +
sizeof (int32) +
sizeof (uint16);
214 data +=
sizeof (int32) +
sizeof (uint16) + (size_t) itemSize;
224 samplePosition = MidiBufferHelpers::getEventTime (
data);
225 auto itemSize = MidiBufferHelpers::getEventDataSize (
data);
226 result =
MidiMessage (
data +
sizeof (int32) +
sizeof (uint16), itemSize, samplePosition);
227 data +=
sizeof (int32) +
sizeof (uint16) + (size_t) itemSize;
ElementType * data() noexcept
Returns a pointer to the first element in the array.
void ensureStorageAllocated(int minNumElements)
Increases the array's internal storage to hold a minimum number of elements.
void clearQuick()
Removes all elements from the array without freeing the array's allocated storage.
int size() const noexcept
Returns the current number of elements in the array.
ElementType * end() noexcept
Returns a pointer to the element which follows the last element in the array.
void removeRange(int startIndex, int numberToRemove)
Removes a range of elements from the array.
ElementType * begin() noexcept
Returns a pointer to the first element in the array.
void insertMultiple(int indexToInsertAt, ParameterType newElement, int numberOfTimesToInsertIt)
Inserts multiple copies of an element into the array at a given position.
Used to iterate through the events in a MidiBuffer.
void setNextSamplePosition(int samplePosition) noexcept
Repositions the iterator so that the next event retrieved will be the first one whose sample position...
~Iterator() noexcept
Destructor.
Iterator(const MidiBuffer &) noexcept
Creates an Iterator for this MidiBuffer.
bool getNextEvent(MidiMessage &result, int &samplePosition) noexcept
Retrieves a copy of the next event from the buffer.
Holds a sequence of time-stamped midi events.
int getFirstEventTime() const noexcept
Returns the sample number of the first event in the buffer.
MidiBuffer & operator=(const MidiBuffer &) noexcept
Makes a copy of another MidiBuffer.
void addEvent(const MidiMessage &midiMessage, int sampleNumber)
Adds an event to the buffer.
int getLastEventTime() const noexcept
Returns the sample number of the last event in the buffer.
void ensureSize(size_t minimumNumBytes)
Preallocates some memory for the buffer to use.
MidiBuffer() noexcept
Creates an empty MidiBuffer.
int getNumEvents() const noexcept
Counts the number of events in the buffer.
bool isEmpty() const noexcept
Returns true if the buffer is empty.
void swapWith(MidiBuffer &) noexcept
Exchanges the contents of this buffer with another one.
void clear() noexcept
Removes all events from the buffer.
void addEvents(const MidiBuffer &otherBuffer, int startSample, int numSamples, int sampleDeltaToAdd)
Adds some events from another buffer to this one.
Array< uint8 > data
The raw data holding this buffer.
Encapsulates a MIDI message.
static int readVariableLengthVal(const uint8 *data, int &numBytesUsed) noexcept
Reads a midi variable-length integer.
static int getMessageLengthFromFirstByte(uint8 firstByte) noexcept
Based on the first byte of a short midi message, this uses a lookup table to return the message lengt...
const uint8 * getRawData() const noexcept
Returns a pointer to the raw midi data.
int getRawDataSize() const noexcept
Returns the number of bytes of data in the message.